目前網絡上好多網站的新聞發布系統都采用了動態服務器技術生成靜態HTML的做法,這樣做的好處是:一是能減輕其服務器的負擔,二是因為生成了HTML靜態頁面,所以其網站被搜索引擎搜索到的機率更大一些。筆者的網站曾經使用PHP這一動態技術來構建新聞發布系統,其原理也就是應用了PHP生成Html靜態頁面的技術,相關平台是 Windows XP Sp2+php4.32+MySQL,因此,在這裡,想簡單地談一下這種做法的思路。這篇文章適合於對PHP+MySQL數據庫操作,SQL語句以及網頁設計有點基礎的朋友,如果您是一個從頭開始學的朋友,那麼請先打好基礎吧!到這裡就不用往下看了。如果您都符合上述條件的話,那麼恭喜您,請接著往下看。但是,在具體動手構建之前,您還要做好以下幾點准備工作。
一、 具備本地調試PHP的功能
在Windows XP操作系統下,筆者建議你可以到網上下載一個PHP+MySQL+APHCHE的服務器套裝,如華軍軟件園,去那裡搜索一下就可以下載到。下載完後默認安裝即可,這樣您就具備了在本地測試PHP的功能了,省去了很多手動配置的麻煩,怎麼樣,簡單吧,OK,這僅僅只是第一步。
二、 構思新聞發布系統所具備的功能
首頁的新聞發布往往是通過後台更新的,後台的更新無非是由添加、編輯、刪除數據等基本的功能所實現的。在這裡,你可以使用網頁設計軟件來構建你的想要的後台界面,其功能的實現當然是要用到PHP喽。這一步建議您先想好新聞發布系統要有的功能。在這裡,如何用PHP添加、編輯、刪除數據就不再重復,因為重點是如何在這基礎上生成靜態技術。
三、 PHP生成Html的技術原理。
哈哈。費話說了那麼多,終於到了該講的地方了。其實,這一原理並不復雜,綜合地來講的話,應該是PHP中一個替換數據語法的應用。OK,講一個簡單范例吧,一步一步地分析!相信聰明的你能看得明白的咯,仔細看好每一步即可,在這裡,只是引導大家如何做而已,具體的可以實踐一下!
(1)在MySQL裡新建一數據庫,命名為 database (可自定義),新建一表,命名為 news(因為是新聞發布嘛,取個好記的名字即可,可自定義),然後建立這幾個字段名:
id (自動遞增,這是關鍵,類型:INT)
title (顧名思義,新聞標題,類型可取 TEXT)
content (新聞內容,類型可取 TEXT)
path (Html文件路徑,類型可取 TEXT)
(2)建立 conn.PHP
這是連接數據庫的PHP文件,你可以把連接數據的語句單獨放在這一文件裡,以後多個需要連接數據庫的文件直接引用這個文件即可。
(3)設計添加新聞的表格 add.form 簡單的源代碼如下:
<form method=”post” action=”add.php”> //提交至 add.PHP
新聞標題:<input type=”text” name=”title” size=”20”><br>
新聞內容:<textarea name=”content” cols=”10” rows=”25”></textarea><br>
<input type=”submit” name=”提交”>
</form>
(4)建立一個 Html 的模板,另存為model.htm,和 add.PHP可以在同一目錄下。
示例源代碼:
<Html>
<body>
此新聞的標題:{title}
此新聞的內容:{content}
</body>
</Html>
{ }大括號內的內容即是要被替換的內容,整個靜態模板的設計可以根據自己的思路,但{ }內被替換的內容必須包含在內,如上面的{title},{content};咔咔~簡單地說,設計好一個很好看的新聞模板後,把要被替換的如{title},{content}等標記放到需要的地方就可以了撒。
(5)詳解 add.PHP 源碼
<?PHP
require_once(“conn.php”); //引用conn.PHP,連接數據庫
$title=$_POST[“title”];
$content=$_POST[“content”]; //獲得表單變量
//以下建立一文本文檔,其值自動計數
$countfile="count.txt";
if(!file_exists($countfile))
{
fopen($countfile,"w"); //如果此文件不存在,則自動建立一個
}
$fp=fopen($countfile,"r");
$num=fgets($fp,20);
$num=$num+1; //每次其值自動加一
fclose($fp);
$fp=fopen($countfile,"w");
fwrite($fp,$num); //更新其值
fclose($fp);
//利用上面自動計數的值獲得Html的路徑$path
$houzui=”.Html”;
$path=$num.$houzui;
//這樣形成的路徑是自動增長的,如1.html,2.html,3.Html……….添加一條新聞便自動加上1
//以下用SQL語句添加數據至表 news
$sql=”insert into news (title,content,path) values (‘”.$title.”’,’”.$content.”’,’”.$path.”’)”;
$query=MySQL_query($sql);
//以下為關鍵之處,把從表單獲得的數據替換模板中的{title},{content}標記 $fp=fopen(“model.htm”,”r”) //只讀打開模板
$str=fread($fp,filesize(“mode.htm”));//讀取模板中內容
$str=str_replace(“{title}”,$title,$str);
$str=str_replace(“{content}”,$content,$str);//替換內容
fclose($fp);
$handle=fopen($path,”w”); //寫入方式打開新聞路徑
fwrite($handle,$str); //把剛才替換的內容寫進生成的Html文件
fclose($handle);
//收尾工作:
echo “<a href=$path target=_blank>查看剛才