PHP產生HTML的技術原理_PHP教程

來源:互聯網
上載者:User
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(因為是新聞發布嘛,取個好記的名字即可,可自訂),...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.