模仿OSO的论坛(一)
程序员文章站
2022-12-26 09:30:58
相信每一个到过oso的人都会对oso的论坛留下极深的印象,这个论坛无论从那一方面来说都是比较出色的。你想不想你的...
相信每一个到过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:(用来显示主题列表)
<html><head><title>疑难问题</title>
<link href="mypic/style.css" rel=stylesheet type=text/css></head>
<body bgcolor=#cccc99 bottommargin=0 leftmargin=0 topmargin=0 marginwidth="0" marginheight="0">
<table border=0 cellpadding=0 cellspacing=0 width="100%">
<tbody>
<script language=javascript
src="mypic/x.js"></script>
<tr>
<td valign=top>只有会员才能在此发言<br>
<table align=center border=0 cellpadding=4 cellspacing=1 width=100% class=body_br >
<tbody>
<td width=45%></font> 主题数: <font
color=#0772b1>
<?php
include "connect.inc.php";
$query = "select count(*) from guestbook where type=1";
$res = mysql_query($query);
$row = mysql_fetch_row($res);
$total=$row[0];
$totalpage=floor($total/20)+1;
echo $total;
?>
</font></td><td width=19%>帖子数: </td>
<td width=1%><font color=#0772b1>
<?php
$query = "select count(*) from guestbook";
$res = mysql_query($query);
$row = mysql_fetch_row($res);
echo $row[0];
?>
</font></td><td width=1%></td><td align=middle width=23%><a
href="post.php"><img
border=0
src="mypic/post.gif"></a></td></tr>
<tr>
<td align=middle bgcolor=#6f6f6f><font color=#ffffff>主
题</font></td>
<td align=middle bgcolor=#6f6f6f><font
color=#ffffff>创建人</font></td>
<td align=middle bgcolor=#6f6f6f><font
color=#ffffff>回复</font></td>
<td align=middle bgcolor=#6f6f6f><font
color=#ffffff>回复人</font></td>
<td align=middle bgcolor=#6f6f6f><font
color=#ffffff>最后回复时间</font></td></tr>
<?php
function tdbackcolor() {
static $colorstr;
if ($colorstr=="#ededed") {
$colorstr="#dedede";
} else {
$colorstr="#ededed";
}
return($colorstr);
}
if (!$page) $page=1;
$ysylimit=($page-1)*20;
$query = "select theme,answer_count,id,name,answer_name,date_format(time_close,'%y-%m-%d') as mydate from guestbook where type=1 order by time_close desc limit ".$ysylimit.",20 ";
$res = mysql_query($query);
for ($i=0; $i<20; $i++) {
$row = @mysql_fetch_array($res);
if(!$row) break;
$colorstr=tdbackcolor();
echo "<tr><td bgcolor=".$colorstr." class=mid><a class=title href='read.php?theme_id=".$row['id']."&page=1'>".$row['theme'];
echo "</a>";
if ($row['answer_count']>5)
{echo "<font ";
echo "class=small color=#666666> <b>分页</b>:";
for ($j=1;$j<=($row['answer_count']-1)/5+1;$j++) echo "<a href='read.php?theme_id=".$row['id']."&page=".$j."'[".$j."][1]</a>";
}
echo "</td>";
echo "<td align=middle bgcolor=".$colorstr.">";
echo $row['name']."</td>";
$ii=$row['answer_count']-1;
echo "<td align=middle bgcolor=".$colorstr." class=mid>".$ii."</td>";
echo "<td align=middle bgcolor=".$colorstr.">";
echo $row['answer_name']."</td>";
echo "<td align=middle bgcolor=".$colorstr."><font color=#ff8800>".$row['mydate']."</font></td></tr>";}
?>
</tbody></table>
<hr size=1 width=100%>
<b>分页</b>:
<?php
$page1=$page-1;
$page2=$page+1;
if ($page==1) echo "<font color=#999999>首页 前页</font> ";
else echo "<a href='faq.php?page=1'>首页</a> <a href='faq.php?page=".$page1."'>前页</a> ";
if ($page==$totalpage) echo "<font color=#999999>后页 尾页</font> ";
else echo "<a href='faq.php?page=".$page2."'>后页</a> <a href='faq.php?page=".$totalpage."'>尾页</a> ";
?>
<form action=faq.php method=post><font class=mid>当前页:<b><?php echo $page."/".$totalpage ?></b> 转到第<select name=page onchange=javascript:location.href=this.options[this.selectedindex].value>
<option selected
<?php
$k=1;
echo "value=faq.php?page=".$k.">".$k."</option>";
for ($k=2;$k<=totalpage;$k++)
echo "<option value=faq.php?page=".$k.">".$k."</option>";
?>
</select> 页</font>
</form></td></tr></tbody></table>
</html>