程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP基礎知識 >> 淺淡PHP生成HTML的思路

淺淡PHP生成HTML的思路

編輯:PHP基礎知識
 

目前網絡上好多網站的新聞發布系統都采用了動態服務器技術生成靜態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>

代碼拷貝框
<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>
[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);


代碼拷貝框
<?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);
[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);


代碼拷貝框
$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);


[Ctrl+A 全部選擇 然後拷貝]
//收尾工作:
echo “<a href=$path target=_blank>查看剛才添加的新聞</a>”;


代碼拷貝框
echo “<a href=$path target=_blank>查看剛才添加的新聞</a>”;

[Ctrl+A 全部選擇 然後拷貝]
OK,整個生成HTML的示例源碼就到這裡,其關鍵是用了替換的方法。
$str=str_replace(“{被替換的內容}”,$替換的內容,$str);

因此,總結一下以上的做法:先設計好新聞模板,把需要被替換的內容用{ }放到模板中相應的位置,然後設計表單,再是最後的表單處理程序,把從表單中獲取的變量替換模板中相應的內容即可,這樣每次都會生成不同的HTML;如果需要修改HTML的內容也是一樣的,獲得修改後的表單內容後,先用 update 語句更新數據庫,再重新替換一下模板中的內容即可;刪除的話,先delete表中要刪除的內容,再用unlink($path) 來刪除HTML的物理文件即可。

 

3.一般的CMS都會記錄內容被浏覽的信息,例如浏覽次數或者浏覽者的IP信息等,靜態頁面要記錄這些信息,可以在模板中加入一個長寬都為0的圖片,指向計數腳本。

以記錄浏覽次數為例:
<img width='0' height='0' src='counter.php?fileID=S001'/>
這樣,計數操作可以放到counter.php中進行,又不會破壞網頁的靜態性。

 

後記:這篇文章我是在網絡上找到的,自己調試了下,加補全了一點代碼,是可以運行的。現帖上自己打的代碼:

<form method="post" action="add.php">
新聞標題:<input type="text" name="title" size="20"><br>
新聞內容:<textarea name="content" cols="16" rows="10"></textarea><br>
<input type="submit" name="提交">
</form>

<?php
require_once "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 += 1;
fclose($fp);
$fp = fopen($countfile,"w");
fwrite($fp,$num);
fclose($fp);

$houzui = ".html";
$path = $num . $houzui;
$sql="insert into news (title,content,path) values ('".$title."','".$content."','".$path."')";

$query = mysql_query($sql);

$filename = "model.html";
$fp = fopen($filename,"r");
$str = fread($fp,filesize($filename));
$str = str_replace("{title}",$title,$str);
$str = str_replace("{content}",$content,$str);
fclose($fp);

$handle = fopen($path,"w");
fwrite($handle,$str);
fclose($handle);
?>
 

 
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved