相信每一個到過OSO的人都會對OSO的論壇留下極深的印象,這個論壇無論從那一方面來說都是比較出色的。你想不想你的主頁也有這么一個漂亮的論壇呢,其實并不太復雜的,下面我們僅從一些基本的部分來實現(xiàn)對OSO論壇的模仿。 由于我僅僅是使用這個論壇作為我的留言板,所以我的論壇可以算是OSO論壇的簡配。1、在我的論壇中只有在用戶登錄后才能發(fā)言,用戶的ID是存在一個叫“cookie_user”的cookie變量中的,2、我的論壇沒有子論壇,3、我沒有統(tǒng)計一個主題的點擊數(shù),4、在OSO論壇中每一個主題前面的表示有沒有新貼子的圖標我也沒設計,5、對于OSO論壇所提供的可選擇的主題排列方式以及顯示時間段我也沒考慮,6、沒有會員發(fā)貼積分的統(tǒng)計,7、沒有版主管理論壇的功能,8、沒有貼子編輯的功能。我們將在最后提到如何在我的程序基礎上擴充這八項功能。 首先是一個數(shù)據(jù)庫的設計,事實上一個論壇牽涉到兩個數(shù)據(jù)表,我們暫且將其命名為user、guestbook,在user表中存儲的是注冊用戶的信息。其創(chuàng)建語句如下: create table my_user( user_id char(12) not null,/*用戶名*/ user_password varchar(8) not null,/*用戶密碼*/ PRIMARY KEY (user_id) ) guestbook中儲存的是貼子內(nèi)容。其創(chuàng)建內(nèi)容如下: CREATE TABLE guestbook ( id bigint DEFAULT '0' NOT NULL auto_increment,/*發(fā)言id,自增字段*/ name varchar(12) NOT NULL,/*主題創(chuàng)建人*/ type tinyint NOT NULL,/*類型0-回復;1-主貼*/ theme varchar(50) NULL,/*主題*/ content blob NOT NULL,/*內(nèi)容*/ icon tinyint NOT NULL,/*表情圖標*/ time_open datetime not NULL,/*主題創(chuàng)建時間*/ time_close datetime not NULL,/*最后回復時間*/ answer_count int not null,/*回復數(shù)*/ 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:(用來連接數(shù)據(jù)庫) <? $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>只有會員才能在此發(fā)言<BR> <TABLE align=center border=0 cellPadding=4 cellSpacing=1 width=100% class=body_br > <TBODY> <TD width=45%></FONT> 主題數(shù): <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%>帖子數(shù): </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>創(chuàng)建人</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> 轉(zhuǎn)到第<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>
|