前言:
目前網絡上好多網站的新聞發佈系統都采用瞭動態服務器技術生成靜態HTML的做法,這樣做的好處是:一是能減輕其服務器的負擔,二是因為生成瞭HTML靜態頁面,所以其網站被搜索引擎搜索到的機率更大一些。筆者的網站曾經使用PHP這一動態技術來構建新聞發佈系統,其原理也就是應用瞭PHP生成HTML靜態頁面的技術,相關平臺是 Windows XP Sp2+php4.32+mysql,因此,在這裡,想簡單地談一下這種做法的思路。這篇文章適合於對PHP+MYSQL數據庫操作,SQL語句以及網頁設計有點基礎的朋友,如果您是一個從頭開始學的朋友,那麼請先打好基礎吧!到這裡就不用往下看瞭。如果您都符合上述條件的話,那麼恭喜您,請接著往下看。但是,在具體動手構建之前,您還要做好以下幾點準備工作。
一、 具備本地調試PHP的功能
在WINDOWS XP操作系統下,筆者建議你可以到網上下載一個PHP+MYSQL+APHCHE的服務器套裝,如華軍軟件園,去那裡搜索一下就可以下載到。下載完後默認安裝即可,這樣您就具備瞭在本地測試PHP的功能瞭,省去瞭很多手動配置的麻煩,怎麼樣,簡單吧,OK,這僅僅隻是第一步。
二、 構思新聞發佈系統所具備的功能
首頁的新聞發佈往往是通過後臺更新的,後臺的更新無非是由添加、編輯、刪除數據等基本的功能所實現的。在這裡,你可以使用網頁設計軟件來構建你的想要的後臺界面,其功能的實現當然是要用到PHP嘍。這一步建議您先想好新聞發佈系統要有的功能。在這裡,如何用PHP添加、編輯、刪除數據就不再重復,因為重點是如何在這基礎上生成靜態技術。
本新聞共2頁,當前在第1頁 1 asp”>2
三、 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>
代碼拷貝框
新聞標題:<input type=”text” name=”title” size=”20”><br>
新聞內容:<textarea name=”content” cols=”10” rows=”25”></textarea><br>
<input type=”submit” name=”提交”>
</form>
[Ctrl+A 全部選擇 然後拷貝]
(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);
代碼拷貝框
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);
[Ctrl+A 全部選擇 然後拷貝]
//利用上面自動計數的值獲得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);
代碼拷貝框
$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);
[Ctrl+A 全部選擇 然後拷貝]
//收尾工作:
echo “<a href=$path target=_blank>查看剛才添加的新聞</a>”;
代碼拷貝框
[Ctrl+A 全部選擇 然後拷貝]
OK,整個生成HTML的示例源碼就到這裡,其關鍵是用瞭替換的方法。
$str=str_replace(“{被替換的內容}”,$替換的內容,$str);
因此,總結一下以上的做法:先設計好新聞模板,把需要被替換的內容用{ }放到模板中相應的位置,然後設計表單,再是最後的表單處理程序,把從表單中獲取的變量替換模板中相應的內容即可,這樣每次都會生成不同的HTML;如果需要修改HTML的內容也是一樣的,獲得修改後的表單內容後,先用 update 語句更新數據庫,再重新替換一下模板中的內容即可;刪除的話,先delete表中要刪除的內容,再用unlink($path) 來刪除HTML的物理文件即可。
本新聞共2頁,當前在第2頁 1 <fo