模仿OSO的论坛(一)

5年以前  |  阅读数:280 次  |  编程语言:PHP 
相信每一个到过OSO的人都会对OSO的论坛留下极深的印象,这个论坛无论从那一方面来说都是比较出色的。你想不想你的主页也有这么一个漂亮的论坛呢,其实并不太复杂的,下面我们仅从一些基本的部分来实现对OSO论坛的模仿。   
由于我仅仅是使用这个论坛作为我的留言板,所以我的论坛可以算是OSO论坛的简配。1、在我的论坛中只有在用户登录后才能发言,用户的ID是存在一个叫"cookie_user"的cookie变量中的,2、我的论坛没有子论坛,3、我没有统计一个主题的点击数,4、在OSO论坛中每一个主题前面的表示有没有新贴子的图标我也没设计,5、对于OSO论坛所提供的可选择的主题排列方式以及显示时间段我也没考虑,6、没有会员发贴积分的统计,7、没有版主管理论坛的功能,8、没有贴子编辑的功能。我们将在最后提到如何在我的程序基础上扩充这八项功能。   
首先是一个数据库的设计,事实上一个论坛牵涉到两个数据表,我们暂且将其命名为user、guestbook,在user表中存储的是注册用户的信息。其创建语句如下:   

create table my_user(
user_id char(12) not null,/用户名/
user_password varchar(8) not null,/用户密码/
PRIMARY KEY (user_id)
)
guestbook中储存的是贴子内容。其创建内容如下:
CREATE TABLE guestbook (
id bigint DEFAULT '0' NOT NULL auto_increment,/发言id,自增字段/
name varchar(12) NOT NULL,/主题创建人/
type tinyint NOT NULL,/类型0-回复;1-主贴/
theme varchar(50) NULL,/主题/
content blob NOT NULL,/内容/
icon tinyint NOT NULL,/表情图标/
time_open datetime not NULL,/主题创建时间/
time_close datetime not NULL,/最后回复时间/
answer_count int not null,/回复数/
answer_name varchar(12) not null,/最后回复人/
main_id bigint null,/主贴id/
PRIMARY KEY (id)/**/
);
程序包含五个php源代码:分别是connect.inc.php,faq.php,read.php,post.php,reply.php,post_end.php
connect.inc.php:(用来连接数据库)
<?
$dbhostname = "localhost";
$dbusername = "";
$dbpassword = "";
$dbName = "";
MYSQL_CONNECT($dbhostname, $dbusername, $dbpassword) OR DIE("Unable to connect to database");
@mysql_select_db( "$dbName") or die( "Unable to select database");
?>

faq.php:(用来显示主题列表)

疑难问题
只有会员才能在此发言
"; echo ""; $ii=$row['answer_count']-1; echo ""; echo ""; echo "";} ?>
 主题数: 帖子数:
主 题 创建人 回复 回复人 最后回复时间
".$row['theme']; echo ""; if ($row['answer_count']>5) {echo " 分页:"; for ($j=1;$j<=($row['answer_count']-1)/5+1;$j++) echo ""; } echo ""; echo $row['name']."".$ii.""; echo $row['answer_name']."".$row['mydate']."

分页首页 前页 "; else echo "首页 前页 "; if ($page==$totalpage) echo "后页 尾页 "; else echo "后页 尾页 "; ?>
当前页: 转到第
 相关文章:
PHP分页显示制作详细讲解
SSH 登录失败:Host key verification failed
获取IMSI
将二进制数据转为16进制以便显示
获取IMEI
文件下载
贪吃蛇
双位运算符
PHP自定义函数获取搜索引擎来源关键字的方法
Java生成UUID
发送邮件
年的日历图
提取后缀名
在Zeus Web Server中安装PHP语言支持
让你成为最历害的git提交人
Yii2汉字转拼音类的实例代码
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Python 2与Python 3版本和编码的对比
php封装的page分页类完整实例