我的论坛源代码(一)


Posted in PHP onOctober 09, 2006

其实写这几篇代码的时间不过近三天而已,事前即没有经过详细思考和计划(可以说一点计划都没有)那天想起做个论坛试试,于是就做起来了,而我也是才接触了将近一个月时间的PHP,以前也没真正写过程序之类的东东,在写这段代码的两天半时间里,有好几次遇到困难,都想放弃,但是我还是写出来了,而且没想到居然能用,所以中间可能有很多隐患也说不清,虽然说是可以用了。
再过两天,我就要去上班,也没时间再仔细地从头到尾检查这些代码了,这也是我放上来的原因之一,还有一个原因是,因为我想让大家一起来看看这些字符,我只是个菜鸟,中间可能有很多捷径没走,也有可能有很多地方不对,而且近两天我改了部份页面的代码,但其它相关的代码没去掉,所以有些地方有点重覆。但是它能正常运行,这是肯定的(至少表面上正常,我在WIN98/APACHE/PHP/MYSQL下用没问题,在网上测试也没问题,其它环境下就不知道了。我只希望和我一样的菜鸟们,或是比我还菜的菜鸟们能从中得到些什么,而那些老鸟及前辈们能来信或留言指出中间的缺点或不足的话,我会更高兴。因为那样的话,我也可从中学到不少东西。我的邮件地址是:hllinyu@netease.com,OICQ:2289230,主页地址是:http://lfox.oso.com.cn
好了,废话说太多了,我希望大家能投入到修改这个论坛源代码的工作中来,让它成为中国人自己开发的免费论坛,让论坛代码成为许许多多像我一样对PHP很感兴趣而又感觉无从下手的朋友们手下的参考资料就行了。下面来看我的论坛吧!
首先介绍要用的两个表存放贴子信息的foxbbs和存放用户信息的useinfo,因为当初考虑到数据空间不是很大,所以选择了MYSQL+TXT的方式来做,所有主题除了内容外都是存放在MYSQL里的,而数据量相对较大的主题内容和回复内容都单独存放扩展名为.FOX和.BBS的TXT格式文件里,在表里加个存放文件名的字段就行了,为了避免文件名重覆,取当前的系统时间来做文件名,比如2001年1月2日11时20分30秒发了一张帖子,文件名就是20010102112030.txt我想这能满足绝大部分的要求了,因为可能没几个论坛会热到每秒钟都有两张或两张以上的新帖出现吧!呵呵……
此论坛的具体情况可见http://lfox.oso.com.cn/foxbbs/foxbbs.php,另外主页面http://lfox.oso.com.cn/index.php上提供源码打包下载,看了源代码可别来捣乱哦。

useinfo 用户信息表  
0   usename    varchar(8)    not null          用户名
1   usepass    varchar(8)    not null          密码
2   useni      varchar(30)   not null 昵称  
3   useoicq    varchar(12)   not null    
4   usesex     int(1)        not null 用户性别  
5   useage     int(2)        not null 用户年龄  
6   usezy      varchar(4)    not null 职业  
7   useaddr    varchar(20)   not null 地址  
8   usemail    varchar(40)   not null 邮箱  
9   useweb     varchar(50)   not null 主页  
10  useqm      varchar(240)  not null  签名   
11  useattr    int(1)        not null 属性   1用户2版主3管理员4站长  
12  useinf     int(1)        not null 是否公开信息 1否2是   
13  useid      int(5)        not auto_increment   primary key   用户ID号
14  usebq      int(1)        not null   表情
15  regdate    datetime;                注册时间
16  enddate    varchar(22)   not null   最后到站时间
17  ftnum      int(4)        not null   发贴数
18  usety      char(1)  not null         

foxbbs 论坛主题表  
0 id int(5) not auto_increment primary key  
1 usename varchar(20) NOT 发帖用户名  
2 ftbq int(1) not 表情  
3 title varchar(40) not 主题  
4 ftdate varchar(22) not 发帖时间  
5 mesname varchar(15) not 内容文件名 20010102055635 我多了留一位,以防意外,其实十四位就足够了。
6 djnum int(4) not 点击数  
7 hfnum int(3) not 回复数  
8 hfdate varchar(24) not 最后回复时间  
9 hfname varchar(20) not 回复文件名
10 hfusename varchar(20) not 最后回复人名
11 ip      varchar(15)
12 lockes int 1

linkfox.inc.php连接数据库用
<?
$dbhostname = "lfox";
$dbusername = "root";
$dbpassword = "root";
$dbName = "flyfox";
MYSQL_CONNECT($dbhostname, $dbusername, $dbpassword) OR DIE("Unable to connect to database");
@mysql_select_db( "$dbName") or die( "Unable to select database");
?>  

PHP 相关文章推荐
Email+URL的判断和自动转换函数
Oct 09 PHP
我的论坛源代码(九)
Oct 09 PHP
php数据库密码的找回的步骤
Jan 12 PHP
PHP中HTML标签过滤技巧
Jan 07 PHP
php实现微信公众平台账号自定义菜单类
Dec 02 PHP
php使用escapeshellarg时中文被过滤的解决方法
Jul 10 PHP
利用php_imagick实现复古效果的方法
Oct 18 PHP
PHP简单实现防止SQL注入的方法
Mar 13 PHP
PHP中使用mpdf 导出PDF文件的实现方法
Oct 22 PHP
java解析json方法总结
May 16 PHP
Yii2框架操作数据库的方法分析【以mysql为例】
May 27 PHP
PHP实现与java 通信的插件使用教程
Aug 11 PHP
我的论坛源代码(二)
Oct 09 #PHP
我的论坛源代码(三)
Oct 09 #PHP
我的论坛源代码(四)
Oct 09 #PHP
PHP的FTP学习(三)
Oct 09 #PHP
我的论坛源代码(六)
Oct 09 #PHP
我的论坛源代码(五)
Oct 09 #PHP
杏林同学录(五)
Oct 09 #PHP
You might like
phpMyAdmin下载、安装和使用入门教程
2007/05/31 PHP
PHP 实现代码复用的一个方法 traits新特性
2015/02/22 PHP
PHP三种方式实现链式操作详解
2017/01/21 PHP
JS判断是否为数字,是否为整数,是否为浮点数的代码
2010/04/24 Javascript
jquery不会自动回收xmlHttpRequest对象 导致了内存溢出
2012/06/18 Javascript
JavaScript执行效率与性能提升方案
2012/12/21 Javascript
深入理解JavaScript系列(27):设计模式之建造者模式详解
2015/03/03 Javascript
jquery获取多个checkbox的值异步提交给php
2015/07/07 Javascript
JavaScript基础篇(6)之函数表达式闭包
2015/12/11 Javascript
Bootstrap选项卡与Masonry插件的完美结合
2016/07/06 Javascript
ReactNative实现图片上传功能的示例代码
2017/07/11 Javascript
Easyui使用Dialog行内按钮布局的实例
2017/07/27 Javascript
webpack配置之后端渲染详解
2017/10/26 Javascript
angular2中Http请求原理与用法详解
2018/01/11 Javascript
js自定义trim函数实现删除两端空格功能
2018/02/09 Javascript
webpack+vuex+axios 跨域请求数据的示例代码
2018/03/06 Javascript
nodejs简单访问及操作mysql数据库的方法示例
2018/03/15 NodeJs
boostrap模态框二次弹出清空原有内容的方法
2018/08/10 Javascript
js实现mp3录音通过websocket实时传送+简易波形图效果
2020/06/12 Javascript
Python实现获取邮箱内容并解析的方法示例
2018/06/16 Python
如何使用pyinstaller打包32位的exe程序
2019/05/26 Python
python读csv文件时指定行为表头或无表头的方法
2019/06/26 Python
Windows下PyCharm2018.3.2 安装教程(图文详解)
2019/10/24 Python
利用matplotlib实现根据实时数据动态更新图形
2019/12/13 Python
Python class的继承方法代码实例
2020/02/14 Python
Django Channel实时推送与聊天的示例代码
2020/04/30 Python
HTML 5 input placeholder 属性如何完美兼任ie
2014/05/12 HTML / CSS
SmartBuyGlasses意大利:购买太阳镜、眼镜和隐形眼镜
2018/11/20 全球购物
澳大利亚玩具剧场:Toy Playhouse
2019/03/03 全球购物
美国轻奢时尚购物网站:REVOLVE(支持中文)
2020/07/18 全球购物
商超业务员岗位职责
2014/03/12 职场文书
大学生个人先进事迹材料范文
2014/05/03 职场文书
教师爱岗敬业演讲稿
2014/05/05 职场文书
财务部会计岗位职责
2015/02/03 职场文书
水电工岗位职责
2015/02/14 职场文书
2015年数学教研组工作总结
2015/05/23 职场文书