您的位置:首页网页设计PHP实例 → 模仿OSO的论坛(一)

模仿OSO的论坛(一)

时间:2004/11/7 3:23:00来源:本站整理作者:蓝点我要评论(0)

 

    相信每一个到过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:(用来显示主题列表)

疑难问题





      

        



  

    
只有会员才能在此发言


      

        

          

          

      

          

          

          

          

          


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 "";  

    echo "";

  $ii=$row['answer_count']-1;

  echo "";

   echo "";

  echo "";}

?>

 主题数:&nbsp;&nbsp;&nbsp;&nbsp;
            color=#0772b1>

                     
                     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;

                     ?>

          
帖子数:

                     
                     $query = "select count(*) from guestbook";

                     $res = mysql_query($query);  

                     $row = mysql_fetch_row($res);  

                     echo $row[0];

                     ?>

            

            href="post.php">
            border=0  

          src="mypic/post.gif">
主  

            题

            color=#ffffff>创建人

            color=#ffffff>回复

            color=#ffffff>回复人

            color=#ffffff>最后回复时间
".$row['theme'];

    echo "
";

    if ($row['answer_count']>5)

    {echo "
   echo "class=small color=#666666>&nbsp;&nbsp;分页:";

    for ($j=1;$j<=($row['answer_count']-1)/5+1;$j++) echo "";  

    }

    echo "
";  

   echo $row['name']."
".$ii."";  

  echo $row['answer_name']."
".$row['mydate']."


      


分页


$page1=$page-1;

$page2=$page+1;

if ($page==1) echo "首页&nbsp;前页&nbsp;";  

else echo "首页&nbsp;前页&nbsp;";  

if ($page==$totalpage) echo "后页&nbsp;尾页&nbsp;";  

else echo "后页&nbsp;尾页&nbsp;";  

?>

当前页:&nbsp;&nbsp;转到第&nbsp;页  

            







相关阅读 Windows错误代码大全 Windows错误代码查询激活windows有什么用Mac QQ和Windows QQ聊天记录怎么合并 Mac QQ和Windows QQ聊天记录Windows 10自动更新怎么关闭 如何关闭Windows 10自动更新windows 10 rs4快速预览版17017下载错误问题Win10秋季创意者更新16291更新了什么 win10 16291更新内容windows10秋季创意者更新时间 windows10秋季创意者更新内容kb3150513补丁更新了什么 Windows 10补丁kb3150513是什么

文章评论
发表评论

热门文章 没有查询到任何记录。

最新文章 我的php文件怎么打开_php运算符怎么写 php 如何生成静态页面的函数PHP生成图片缩略图PHP session常见问题集锦及解决办法PHP实现同步远程Mysql

人气排行 DEDE在文章列表文章没有缩略图的不显示图片php+mysq修改用户密码我的php文件怎么打开_如何打开php文件的办法FCKeditor的配置和使用方法使用dedecms建站教程PHP+Ajax实现分页技术图片存储与浏览一例Linux+Apache+PHP+MySQLPHP生成图片缩略图