在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>查看剛才添加的新聞</a>”;
複製代碼
OK,整個產生HTML的樣本源碼就到這裡,其關鍵是用了替換的方法。
- $str=str_replace(“{被替換的內容}”,$替換的內容,$str);
複製代碼
因此,總結一下以上的做法:先設計好新聞模板,把需要被替換的內容用{ }放到模板中相應的位置,全球安防網然後設計表單,再是最後的表單處理程式,把從表單中擷取的變數替換模板中相應的內容即可,這樣每次都會產生不同的HTML;如果需要修改HTML的內容也是一樣的,獲得修改後的表單內容後,先用 update 語句更新資料庫,再重新替換一下模板中的內容即可;刪除的話,先delete表中要刪除的內容,再用unlink($path) 來刪除HTML的物理檔案即可。 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>查看剛才添加的新聞</a>”;
複製代碼
OK,整個產生HTML的樣本源碼就到這裡,其關鍵是用了替換的方法。
- $str=str_replace(“{被替換的內容}”,$替換的內容,$str);
複製代碼
因此,總結一下以上的做法:先設計好新聞模板,把需要被替換的內容用{ }放到模板中相應的位置,然後設計表單,再是最後的表單處理程式,把從表單中擷取的變數替換模板中相應的內容即可,這樣每次都會產生不同的HTML;如果需要修改HTML的內容也是一樣的,獲得修改後的表單內容後,先用 update 語句更新資料庫,再重新替換一下模板中的內容即可;刪除的話,先delete表中要刪除的內容,再用unlink($path) 來刪除HTML的物理檔案即可。