1)在MYSQL裡建立一資料庫,命名為 database (可自訂),建立一表,命名為 news(因為是新聞發布嘛,取個好記的名字即可,可自訂),然後建立這幾個欄位名:
id (自動遞增,這是關鍵,類型:INT)
title (顧名思義,新聞標題,類型可取 TEXT)
content (新聞內容,類型可取 TEXT)
path (HTML檔案路徑,類型可取 TEXT)
2)建立 conn.php
這是串連資料庫的PHP檔案,你可以把串連資料的語句單獨放在這一檔案裡,以後多個需要串連資料庫的檔案直接引用這個檔案即可。
3)設計添加新聞的表格 add.form 簡單的原始碼如下:
4)建立一個 HTML 的模板,另存新檔model.htm,和 add.php可以在同一目錄下。
樣本原始碼:
此新聞的標題:{title}
此新聞的內容:{content}
{ }大括弧內的內容即是要被替換的內容,整個靜態模板的設計可以根據自己的思路,但{ }內被替換的內容必須包含在內,如上面的{title},{content};哢哢~簡單地說,設計好一個很好看的新聞模板後,把要被替換的如 {title},{content}等標記放到需要的地方就可以了撒。
5)詳解 add.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 “查看剛才添加的新聞”;
OK,整個產生HTML的樣本源碼就到這裡,其關鍵是用了替換的方法。
$str=str_replace(“{被替換的內容}”,$替換的內容,$str);
因此,總結一下以上的做法:先設計好新聞模板,把需要被替換的內容用{ }放到模板中相應的位置,然後設計表單,再是最後的表單處理程式,把從表單中擷取的變數替換模板中相應的內容即可,這樣每次都會產生不同的HTML;如果 需要修改HTML的內容也是一樣的,獲得修改後的表單內容後,先用 update 語句更新資料庫,再重新替換一下模板中的內容即可;刪除的話,先delete表中要刪除的內容,再用unlink($path) 來刪除HTML的物理檔案即可。
http://www.bkjia.com/PHPjc/371664.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/371664.htmlTechArticle1)在MYSQL裡建立一資料庫,命名為 database (可自訂),建立一表,命名為 news(因為是新聞發布嘛,取個好記的名字即可,可自訂),...