当前位置: 首页 > 图文教程 > 网络编程 > PHP > 一个模仿oso的php论坛程序(之一)

PHP
一贴学会PHP 新手入门教程
用PHP的ob_start() 控制您的浏览器cache
谈谈新手如何学习PHP 默默经典版本
黑夜路人出的几道php笔试题
一些 PHP 管理系统程序中的后门
用php获取本周,上周,本月,上月,本季度日期的代码
PHP 简单数组排序实现代码
PHP 多维数组排序实现代码
php 全局变量范围分析
php_xmlhttp 乱码问题解决方法
PHP 数组学习排序全接触
php Sql Server连接失败问题及解决办法
PHP 翻页 实例代码
php 随机数的产生、页面跳转、件读写、文件重命名、switch语句
PHP 5.3.0 安装分析心得
php 生成WML页面方法详解
php 取得瑞年与平年的天数的代码
php empty函数 使用说明
php natsort内核函数浅析
PHP 源代码分析 Zend HashTable详解

PHP 中的 一个模仿oso的php论坛程序(之一)


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-12   浏览: 185 ::
收藏到网摘: n/a

我经常使用oso的论坛,个人感觉挺好的,因此模仿oso的界面编了一个程序,与大家共享。
程序由三部分组成,即显示主题信息,显示论坛信息,增加论坛信息,主题与论坛内容采用主从表关系。
表结构如下:
drop table fr_t_forumtitle;
create table fr_t_forumtitle(
id integer,
state varchar(1),
readcount integer,
replycount integer,
title varchar(100),
createman varchar(20),
replyman varchar(20),
replytime datetime);
drop table fr_t_forumcontent;
create table fr_t_forumcontent(
id integer,
replyman varchar(20),
replytime datetime,
replyemail varchar(100),
replyhttp varchar(100),
replyface smallint,
content text);
drop table fr_t_parameter;
create table fr_t_parameter(
code varchar(10),
name varchar(40),
content varchar(10));
insert into fr_t_parameter(code,name,content) values('pageline','分页数','20'); /* 调整该参数可以修改每页行数 */
程序1:mainforum.php
<html>
<head>
<link rel="STYLESHEET" type="text/css" href="fp_zhangcg.css">
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<meta name="Microsoft Theme" content="none">
<meta name="Microsoft Border" content="none">
<title>论坛</title>
</head>
<body bgcolor="#C0C0C0" background="/upload/tech/20091012/20091012014137_979d472a84804b9f647bc185a877a8b5.gif">
<?
include ("c:mydbheader.inc");
?>
<table width="100%" border="0">
<tr class="text">
<td width="50%"> <div align="left">当前位置:主页——论坛</div> </td>
<td width="20%"> <div align="center"> </div> </td>
<td width="10%"> <div align="center">
<A href="addmember.php" target=_blank>会员注册</A></div> </td>
<td width="10%"> <div align="center">论坛搜索</div> </td>
<td width="10%"> <div align="center"> </div> </td>
</table>

<?
$dbh = mysql_connect('localhost:3306','root','');
mysql_select_db('test');
$res=mysql_query("SELECT content FROM fr_t_parameter where code = 'pageline'",$dbh);
$row=mysql_fetch_array($res);
global $pageline;
$pageline = $row["content"];
if (empty($pageline)) {
$res=mysql_query("insert into fr_t_parameter(code,name,content) values('pageline','分页数','20')",$dbh);
$row=mysql_fetch_array($res);
$pageline = 20;
}
$res=mysql_query("SELECT COUNT(*) AS rcnt FROM fr_t_forumtitle",$dbh);
$row=mysql_fetch_array($res);
$rcount = $row["rcnt"];
$res=mysql_query("SELECT COUNT(*) AS rcnt_con FROM fr_t_forumcontent",$dbh);
$row=mysql_fetch_array($res);
$rcon_count = $row["rcnt_con"];
print '<table width="100%" border="0">';
print '<tr class="text">';
print '<td width="15%"> </td>';
print '<td width="35%"> <div align="left"> ';
print "主题数:".$rcount." 帖子数:".$rcon_count;
print '<td width="35%"> <div align="right"> ';
print '<a href="addforum.php?theme_id=0" target="_top"><img src="/upload/tech/20091012/20091012014138_e57c6b956a6521b28495f2886ca0977a.gif" alt="加新帖子" border="0"></a>';
print '<td width="15%"> </td>';
print '</td></table>';

$pages=ceil($rcount / $pageline); //$pages变量现在包含所需的页数
if (empty($offset)) {
$offset=1;
$curline = 0;
} else
$curline = ($offset - 1) * $pageline;
//打印表头
print '<table width="100%" border="0">';
print '<tr class="text"> <td width="50%"> <div align="center">';
if ($offset <> 1) { //如果偏移量是0,不显示前一页的链接
$newoffset=$offset - 1;
print "<a href='$PHP_SELF?offset=$newoffset'>前一页</a>";
} else {
print "前一页";
print " ";
}
//计算总共需要的页数
$pages=ceil($rcount/$pageline); //$pages变量现在包含所需的页数

for ($i=1; $i <= $pages; $i++) {
$temps = "<a href='".$PHP_SELF.'?offset='.$i."'>".$i."</a>";
print $temps;
print " ";
}
//检查是否是最后一页
if ($pages!=0 && $offset!=$pages) {
$newoffset=$offset+1;
print "<a href='$PHP_SELF?offset=$newoffset'>下一页</a>";
} else print "下一页";
print '</div> </td>';
print '<td width="50%"> <div align="center">';
print "当前页:".$offset." 共".$pages."页";
print '</div> </td>';
print "</table>";
//处理详细信息
print '<table width="100%" border="1">';
print '<tr class="text"> ';
print '<td width="6%"> <div align="center">New</div> </td>';
print '<td width="5%"> <div align="center">点击</div> </td>';
print '<td width="53%"> <div align="center">主题</div> </td>';
print '<td width="10%"> <div align="center">创建人</div> </td>';
print '<td width="5%"> <div align="center">回复</div> </td>';
print '<td width="11%"> <div align="center">最后修改时间 </div> </td>';
print '<td width="10%"> <div align="center">回复人</div> </td>';
print '</tr>';
$query = 'select id,state,readcount,title,createman,replycount,replytime,replyman
from fr_t_forumtitle order by replytime desc LIMIT '.$curline.',20';
$res = mysql_query($query, $dbh);
// $li_rownum = mysql_num_rows($res);
// for ($i=1; $i<=$li_rownum; $i++) {
// $row = mysql_fetch_row($res);
while ($row = mysql_fetch_array($res)) {
print '<tr class="text"> ';
print '<td width="6%"> '.$row["state"].'</td>';
print '<td width="5%"><div align="center">'.$row["readcount"].'</td>';
$tempstr = "<a href='readforum.php?readflag=".$row["id"]."'>".$row['title']."</a>";
print '<td width="53%"> '.$tempstr.'</td>';
// print '<td width="48%">'.$row["title"].'</td>';
print '<td width="9%"> '.$row["createman"].'</td>';
print '<td width="5%"><div align="center">'.$row["replycount"].'</td>';
$temptime = substr($row["replytime"],5,11);
print '<td width="11%"> '.$temptime.'</td>';
print '<td width="10%"> '.$row["replyman"].'</td>';
print '</tr>';
}
print "</table>";
//打印表尾
print '<table width="100%" border="0">';
print '<tr class="text"> <td width="50%"> <div align="center">';
if ($offset <> 1) { //如果偏移量是0,不显示前一页的链接
$newoffset=$offset - 1;
print "<a href='$PHP_SELF?offset=$newoffset'>前一页</a>";
} else {
print "前一页";
print " ";
}
//计算总共需要的页数
for ($i=1; $i <= $pages; $i++) {
$temps = "<a href='".$PHP_SELF.'?offset='.$i."'>".$i."</a>";
print $temps;
print " ";
}
//检查是否是最后一页
if ($pages!=0 && $offset!=$pages) {
$newoffset=$offset+1;
print "<a href='$PHP_SELF?offset=$newoffset'>下一页</a>";
} else print "下一页";
print '</div> </td>';
print '<td width="50%"> <div align="center">';
print "当前页:".$offset." 共".$pages."页";
print '</div> </td>';
print "</table>";
//end of 打印表尾
?>
<?
include ("c:mydbfooter.inc");
?>
</body>
</html>