我经常使用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="backcolor.GIF"> <? include ("c:mydbheader.inc"); ?> <table width="100%" border="0"> <tr class="text"> <td width="50%"> <p align="left">当前位置:主页——论坛</p> </td> <td width="20%"> <p align="center"> </p> </td> <td width="10%"> <p align="center"> <A href="addmember.php" target=_blank>会员注册</A></p> </td> <td width="10%"> <p align="center">论坛搜索</p> </td> <td width="10%"> <p align="center"> </p> </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%"> <p align="left"> '; print "主题数:".$rcount." 帖子数:".$rcon_count; print '<td width="35%"> <p align="right"> '; print '<a href="addforum.php?theme_id=0" target="_top"><img src="post.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%"> <p 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 '</p> </td>'; print '<td width="50%"> <p align="center">'; print "当前页:".$offset." 共".$pages."页"; print '</p> </td>'; print "</table>"; //处理详细信息 print '<table width="100%" border="1">'; print '<tr class="text"> '; print '<td width="6%"> <p align="center">New</p> </td>'; print '<td width="5%"> <p align="center">点击</p> </td>'; print '<td width="53%"> <p align="center">主题</p> </td>'; print '<td width="10%"> <p align="center">创建人</p> </td>'; print '<td width="5%"> <p align="center">回复</p> </td>'; print '<td width="11%"> <p align="center">最后修改时间 </p> </td>'; print '<td width="10%"> <p align="center">回复人</p> </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%"><p 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%"><p 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%"> <p 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 '</p> </td>'; print '<td width="50%"> <p align="center">'; print "当前页:".$offset." 共".$pages."页"; print '</p> </td>'; print "</table>"; //end of 打印表尾 ?> <? include ("c:mydbfooter.inc"); ?> </body> </html>

phpssionsStrackuserdataacrossmultiplepagerequestsusingauniqueidstoredinacookie.here'showtomanageetheemefectively:1)Startassession withsession_start()andstoredatain $ _ session.2)RegeneratesseSsessidafterloginwithsession_id(the topreventes_id)

PHPでは、次の手順を通じてセッションデータを繰り返すことができます。1。session_start()を使用してセッションを開始します。 2。$ _Sessionアレイのすべてのキー価値ペアを介してforeachループを反復します。 3.複雑なデータ構造を処理する場合、is_array()またはis_object()関数を使用し、print_r()を使用して詳細情報を出力します。 4.トラバーサルを最適化する場合、ページングを使用して、一度に大量のデータの処理を避けることができます。これにより、実際のプロジェクトでPHPセッションデータをより効率的に管理および使用するのに役立ちます。

このセッションは、サーバー側の状態管理メカニズムを介してユーザー認証を実現します。 1)セッションの作成と一意のIDの生成、2)IDはCookieを介して渡されます。3)サーバーストアとIDを介してセッションデータにアクセスします。

tostoreauser'snameInappession、starthessession withsession_start()、thensignthenameto $ _session ['username']。1)ousession_start()toinitializethessession.2)assighttheuser'snameto $ _ session ['username']

PHPSESSIONの障害の理由には、構成エラー、Cookieの問題、セッションの有効期限が含まれます。 1。構成エラー:正しいセッションをチェックして設定します。save_path。 2.Cookieの問題:Cookieが正しく設定されていることを確認してください。 3.セッションの有効期限:セッションを調整してください。GC_MAXLIFETIME値はセッション時間を延長します。

PHPでセッションの問題をデバッグする方法は次のとおりです。1。セッションが正しく開始されるかどうかを確認します。 2.セッションIDの配信を確認します。 3.セッションデータのストレージと読み取りを確認します。 4.サーバーの構成を確認します。セッションIDとデータを出力し、セッションファイルのコンテンツを表示するなど、セッション関連の問題を効果的に診断して解決できます。

session_start()への複数の呼び出しにより、警告メッセージと可能なデータ上書きが行われます。 1)PHPは警告を発し、セッションが開始されたことを促します。 2)セッションデータの予期しない上書きを引き起こす可能性があります。 3)session_status()を使用してセッションステータスを確認して、繰り返しの呼び出しを避けます。

PHPでのセッションライフサイクルの構成は、session.gc_maxlifetimeとsession.cookie_lifetimeを設定することで達成できます。 1)session.gc_maxlifetimeサーバー側のセッションデータのサバイバル時間を制御します。 0に設定すると、ブラウザが閉じているとCookieが期限切れになります。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

ホットトピック









