国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > PHP > 正文

模仿OSO的論壇(一)

2024-05-04 23:01:47
字體:
來源:轉載
供稿:網友
  相信每一個到過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> 主題數:&nbsp;&nbsp;&nbsp;&nbsp;<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']."&amp;page=1'>".$row['theme'];
    echo "</a>";
    if ($row['answer_count']>5)
    {echo "<font ";
   echo "class=small color=#666666>&nbsp;&nbsp;<b>分頁</b>:";
    for ($j=1;$j<=($row['answer_count']-1)/5+1;$j++) echo "<a href='read.php?theme_id=".$row['id']."&amp;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>首頁&nbsp;前頁</font>&nbsp;";  
else echo "<a href='faq.php?page=1'>首頁</a>&nbsp;<a href='faq.php?page=".$page1."'>前頁</a>&nbsp;";  
if ($page==$totalpage) echo "<font color=#999999>后頁&nbsp;尾頁</font>&nbsp;";  
else echo "<a href='faq.php?page=".$page2."'>后頁</a>&nbsp;<a href='faq.php?page=".$totalpage."'>尾頁</a>&nbsp;";  
?>
<form action=faq.php method=post><font class=mid>當前頁:<b><?php echo $page."/".$totalpage ?></b>&nbsp;&nbsp;轉到第<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>&nbsp;頁</font>  
            </form></td></tr></tbody></table>
</html>

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 子洲县| 瓮安县| 苏州市| 武强县| 顺义区| 突泉县| 潍坊市| 莆田市| 蒲江县| 织金县| 阿图什市| 筠连县| 绥宁县| 岗巴县| 顺义区| 英德市| 呼玛县| 同心县| 义马市| 布拖县| 和龙市| 莫力| 芮城县| 蓝田县| 寻甸| 兴安盟| 乌拉特后旗| 霍山县| 邵东县| 绥德县| 东台市| 突泉县| 湄潭县| 靖宇县| 台湾省| 嘉定区| 庆元县| 上思县| 精河县| 精河县| 中山市|