用php生成靜態html頁面


因為每次用戶點擊動態鏈接的時候都會對服務器發送數據查詢的要求

對於一個訪問量可能達百萬千萬級別的網站來說 這無疑是服務器一個大大的負擔

所以把動態數據轉換成靜態html頁面就成了節省人力物力的首選

因為此前沒有相應的經驗 剛開始的時候覺得這個技術很神秘

但在看了一些例子以后發現並不是那么復雜(不過網上的資料並不是特別詳細)

經過一個上午加中下午的試驗 終於把該做的任務完成了 下面是一些心得和一個簡單的例子

希望大蝦們不要笑話

 

一般來說 用php轉換輸出html頁面有兩種辦法 引用大蝦的文章如下:

第一種:利用模板。目前PHP的模板可以說是很多了,有功能強大的smarty,還有簡單易用的smarttemplate等。它們每一種模板,都有一個獲取輸出內容的函數。我們生成靜態頁面的方法,就是利用了這個函數。用這個方法的優點是,代碼比較清晰,可讀性好。

 

這里我用smarty做例子,說明如何生成靜態頁:

 

  1. <?php
  2. require("smarty/Smarty.class.php");
  3. $t = new Smarty;
  4. $t->assign("title","Hello World!");
  5. $content = $t->fetch("templates/index.htm");
  6. //這里的 fetch() 就是獲取輸出內容的函數,現在$content變量里面,就是要顯示的內容了
  7. $fp = fopen("archives/2005/05/19/0001.html", "w");
  8. fwrite($fp, $content);
  9. fclose($fp);
  10. ?>

 

 

 

第二種方法:利用ob系列的函數。這里用到的函數主要是 ob_start(), ob_end_flush(), ob_get_content(),其中ob_start()是打開瀏覽器緩沖區的意思,打開緩沖后,所有來自PHP程序的非文件頭信息均不會發送,而是保存在內部緩沖區,直到你使用了ob_end_flush().而這里最重要的一個函數,就是ob_get_contents(),這個函數的作用是獲取緩沖區的內容,相當於上面的那個fetch(),道理一樣的。

 

 

  1. <?php
  2. ob_start();
  3. echo "Hello World!";
  4. $content = ob_get_contents();//取得php頁面輸出的全部內容
  5. $fp = fopen("archives/2005/05/19/0001.html", "w");
  6. fwrite($fp, $content);
  7. fclose($fp);
  8. ?>

 

我選用的第2種方法 也就是用ob系列的函數

我剛開始看這個的時候有點不太明白 后來才知道ob是output buffering的意思 也就是輸出緩存

當你准備輸出的時候 所有的數據都保存在ob里面 服務器解析完php以后 把所有要輸出到客戶端的html代碼都存放在ob里面 如果我們要輸出html靜態頁面 只要把緩存取出來寫入一個html頁面即可

所以原理其實是很簡單的

這里用到了幾個函數 由於我初學php 很多函數我還不了解 所以這里也說明一下 希望可以幫助大家

 

ob_start():開始“捕捉”緩存 也就是從這里開始 打開瀏覽器的緩存

ob_end_flush():關閉瀏覽器緩存

ob_get_content():讀取緩存內容

fopen(”文件路徑”,”打開模式”)打開文件 這個函數的打開模式有好幾種 下面介紹幾種主要的模式:

“r” 只讀方式打開,將文件指針指向文件頭。

“r+” 讀寫方式打開,將文件指針指向文件頭。

“w” 寫入方式打開,將文件指針指向文件頭並將文件大小截為零。如果文件不存在則嘗試創建之。

“w+” 讀寫方式打開,將文件指針指向文件頭並將文件大小截為零。如果文件不存在則嘗試創建之。

fwrite(”文件名稱”,”寫入內容”) 寫入文件

fclose() 關閉文件

 

由於我要轉換的html文件非常多 可能有幾百個 所以這里不能靜態指定fopen的路徑 大家可以設置一個路徑變量 里面可以保存用戶傳來的id等信息 方便進行html文件命名 下面是我結合上次php讀取xml數據的一個簡單例子

 

  1. <?php
  2. ob_start();//打開瀏覽器緩存
  3.  
  4. //下面是讀取xml數據
  5. $parser = xml_parser_cr&#101;ate(); //創建一個parser編輯器
  6. xml_set_element_handler($parser, "startElement", "endElement");//設立標簽觸發時的相應函數 這里分別為startElement和endElenment
  7. xml_set_character_data_handler($parser, "characterData");//設立數據讀取時的相應函數
  8. $xml_file="1.xml";//指定所要讀取的xml文件,可以是url
  9. $filehandler = fopen($xml_file, "r");//打開文件
  10.  
  11.  
  12. while ($data = fread($filehandler, 4096)) 
  13. {
  14. xml_parse($parser, $data, feof($filehandler));
  15. }//每次取出4096個字節進行處理
  16.  
  17. fclose($filehandler);
  18. xml_parser_free($parser);//關閉和釋放parser解析器
  19.  
  20.  
  21. $name=false;
  22. $position=false;
  23. function startElement($parser_instance, $element_name, $attrs) //起始標簽事件的函數
  24. {
  25. global $name,$position;
  26. if($element_name=="NAME")
  27. {
  28. $name=true;
  29. $position=false;
  30. echo "名字:";
  31. }
  32. if($element_name=="POSITION")
  33. {$name=false;
  34. $position=true;
  35. echo "職位:";
  36. }
  37. }
  38.  
  39. function characterData($parser_instance, $xml_data) //讀取數據時的函數
  40. {
  41. global $name,$position;
  42. if($position)
  43. echo $xml_data."<br />";
  44. if($name)
  45. echo $xml_data."<br />";
  46. }
  47.  
  48. function endElement($parser_instance, $element_name) //結束標簽事件的函數
  49. {
  50. global $name,$position;
  51. $name=false;
  52. $position=false;
  53. }
  54. //xml數據讀取完畢
  55.  
  56. $htmlname=$id.".html";//$id可以自己定義 這里代表用戶傳來的id
  57. $htmlpath="archives/".$htmlname; //設置路徑變量
  58. $content = ob_get_contents();//取得php頁面輸出的全部內容
  59. $fp = fopen($htmlpath, "w");
  60. fwrite($fp, $content);
  61. fclose($fp);
  62. ?>

 

Related posts:

  1. 一個用PHP讀取XML數據的簡單例子 今天工作上碰到一個問題 由於我們的項目數據太少 所以需要從web search那邊借調數據 他們只給我們提供了一個xml的接口 因此我們需要把xml的數據轉化成html呈現給大家 由於項目是基於php的 所以就摒棄了用js來讀取xml選擇了繼續使用php 不過我以前從來沒有做過此類的嘗試 所以找了很多網上資料...
  2. 用php實現文件安全下載 最近在研究php實現文件下載的問題,按道理來說,一般的文件下載很簡單,建立一個鏈接指向到目標文件就可以了,但是這樣就直接暴露了文件所在路徑,給盜鏈者打開了大門,並且可能會有安全隱患,一般來說,要實現安全的文件下載,在php下一般是利用header和fread這么來做的: 第一步 假設你要下載的是一個torrent的文件,那么先建立一個動態php文件,用戶點擊下載文件的時候直接鏈接到這個php並傳回與文件位置相關的參數以幫助這個php能從數據庫中取出文件所在的真實位置;這樣做的另外一個好處是,可以通過這個php來對下載進行統計計數;這個過程並不難,所以就不寫代碼了,主要是對數據庫的查詢,假設文件的真實位置是$fileAdd,文件名為$fileName; 第二步 得到文件所在的真實位置以后,有人會用header的location直接重定向到這個文件,但是這樣仍然是不安全的,因為某些下載軟件還是可以通過重定向分析獲得你的文件位置信息,因此需要用另外一種方法,就是php的文件處理API函數,這里主要是運用fread函數把文件直接吐給瀏覽器,讓瀏覽器提示用戶下載,所有的這些處理都是在服務器端完成的,因此用戶是不會知道文件具體位置信息的,具體代碼如下: Header("content-type:application/octet-stream"); Header("content-disposition:attatchment;filename:".$fileName.".torrent"); if(file_exists($fileAdd) && $file=fopen($fileAdd,"r"))//判斷文件是否存在並打開...
  3. PHP優秀的文件訪問功能 這些天和php的親密接觸讓我越來越喜歡這個語言OS的語言就是好 很多人為它寫函數 綜合起大家的力量這樣的語言是最有發展前途的今天和大家介紹一下php的文件訪問功能: php的文件訪問功能非常強大,當然強大並不意味着難,在互聯網這個領域,越強大代表越簡單,因為很好用。在php里面,涉及到file訪問的函數有file()、fopen()、readfile()和get_file_content()等等。這里跟大家介紹最簡單實用的file()函數,其他的函數運用其實都差不多,大家可以去查php手冊。 下面是php手冊當中對file()函數的簡單介紹: 引用內容 file (PHP 3, PHP...
  4. 分享一個php遍歷目錄的函數 工作上有需要,自己寫了一個,代碼如下: function outputDirFile($dir) { if ($handle = opendir($dir)) {     while (false...
  5. thebeststuff圖集的生成方法 之前發表的一個文章引發了一些很激烈的討論,事實上大家誤解了我的意思,我最想知道的是它的生成流程,而不是具體技術細節,但是不管如何,在這里謝謝各位熱心留言的朋友了,這個周末在家我利用空暇時間把自己的一些想法用php表達了出來,初步成功地實現了這種效果,現在放上來和大家分享,下面是我利用GD隨機挑選位置生成的圖片: 要解決這個問題的關鍵在於圖片位置的選擇,具體來說分為兩步: 1. 隨機選擇一個位置(x、y坐標); 2. 根據圖片的寬度、高度以及x、y坐標判斷此位置是否可以放圖; 第一個步驟很好做,先用GD生成一張空白圖片(比如300*100),然后在空白圖中隨機選一個坐標用來放置讀入的新圖片即可; 第二步稍微復雜一點,因為要判斷之前的坐標是否能夠放置新圖片,這里需要對之前已經有圖片的位置做一個信息保存,以方便去逐一對比,我在這里使用了一個二維數組來保存之前圖片的位置信息,類似於數據庫中的一組數據,第一維是圖片,第二維是圖片坐標信息,包括x1、y1、x2、y2四個組成部分;有了這個數組,我們就可以在程序中循環判斷哪個區域對於當前圖片來說是可用的,然后遞歸調用GD的圖片copy生成函數就可以了。 下面是我的php代碼: 下載:...


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM