php生成靜態(tài)html頁面的方法(2種方法)
因為每次用戶點擊動態(tài)鏈接的時候都會對服務器發(fā)送數(shù)據(jù)查詢的要求,對于一個訪問量可能達百萬千萬級別的網(wǎng)站來說 這無疑是服務器一個大大的負擔,所以把動態(tài)數(shù)據(jù)轉換成靜態(tài)html頁面就成了節(jié)省人力物力的首選。
因為此前沒有相應的經(jīng)驗 剛開始的時候覺得這個技術很神秘,但在看了一些例子以后發(fā)現(xiàn)并不是那么復雜(不過網(wǎng)上的資料并不是特別詳細),經(jīng)過一個上午加中下午的試驗 終于把該做的任務完成了 下面是一些心得和一個簡單的例子
希望大蝦們不要笑話我哈
一般來說 用php轉換輸出html頁面有兩種辦法 引用大蝦的文章如下:
第一種:利用模板。
目前PHP的模板可以說是很多了,有功能強大的smarty,還有簡單易用的smarttemplate等。它們每一種模板,都有一個獲取輸出內(nèi)容的函數(shù)。我們生成靜態(tài)頁面的方法,就是利用了這個函數(shù)。用這個方法的優(yōu)點是,代碼比較清晰,可讀性好。
這里我用smarty做例子,說明如何生成靜態(tài)頁:
<?php require("smarty/Smarty.class.php"); $t = new Smarty; $t->assign("title","Hello World!"); $content = $t->fetch("templates/index.htm"); //這里的 fetch() 就是獲取輸出內(nèi)容的函數(shù),現(xiàn)在$content變量里面,就是要顯示的內(nèi)容了 $fp = fopen("archives/2005/05/19/0001.html", "w"); fwrite($fp, $content); fclose($fp); ?>
第二種方法:利用ob系列的函數(shù)。
這里用到的函數(shù)主要是 ob_start(), ob_end_flush(), ob_get_content(),其中ob_start()是打開瀏覽器緩沖區(qū)的意思,打開緩沖后,所有來自PHP程序的非文件頭信息均不會發(fā)送,而是 保存在內(nèi)部緩沖區(qū),直到你使用了ob_end_flush().而這里最重要的一個函數(shù),就是ob_get_contents(),這個函數(shù)的作用是獲取 緩沖區(qū)的內(nèi)容,相當于上面的那個fetch(),道理一樣的。
<?php ob_start(); echo "Hello World!"; $content = ob_get_contents();//取得php頁面輸出的全部內(nèi)容 $fp = fopen("archives/2005/05/19/0001.html", "w"); fwrite($fp, $content); fclose($fp); ?>
我選用的第2種方法 也就是用ob系列的函數(shù)
我剛開始看這個的時候有點不太明白 后來才知道ob是output buffering的意思 也就是輸出緩存
當你準備輸出的時候 所有的數(shù)據(jù)都保存在ob里面 服務器解析完php以后 把所有要輸出到客戶端的html代碼都存放在ob里面 如果我們要輸出html靜態(tài)頁面 只要把緩存取出來寫入一個html頁面即可
所以原理其實是很簡單的
這里用到了幾個函數(shù) 由于我初學php 很多函數(shù)我還不了解 所以這里也說明一下 希望可以幫助大家
ob_start():開始“捕捉”緩存 也就是從這里開始 打開瀏覽器的緩存
ob_end_flush():關閉瀏覽器緩存
ob_get_content():讀取緩存內(nèi)容
fopen(”文件路徑”,”打開模式”)打開文件 這個函數(shù)的打開模式有好幾種 下面介紹幾種主要的模式:
“r” 只讀方式打開,將文件指針指向文件頭。
“r+” 讀寫方式打開,將文件指針指向文件頭。
“w” 寫入方式打開,將文件指針指向文件頭并將文件大小截為零。如果文件不存在則嘗試創(chuàng)建之。
“w+” 讀寫方式打開,將文件指針指向文件頭并將文件大小截為零。如果文件不存在則嘗試創(chuàng)建之。
fwrite(”文件名稱”,”寫入內(nèi)容”) 寫入文件
fclose() 關閉文件
由于我要轉換的html文件非常多 可能有幾百個 所以這里不能靜態(tài)指定fopen的路徑 大家可以設置一個路徑變量 里面可以保存用戶傳來的id等信息 方便進行html文件命名 下面是我結合上次php讀取xml數(shù)據(jù)的一個簡單例子
<?php ob_start();//打開瀏覽器緩存 //下面是讀取xml數(shù)據(jù) $parser = xml_parser_create(); //創(chuàng)建一個parser編輯器 xml_set_element_handler($parser, "startElement", "endElement");//設立標簽觸發(fā)時的相應函數(shù) 這里分別為startElement和endElenment xml_set_character_data_handler($parser, "characterData");//設立數(shù)據(jù)讀取時的相應函數(shù) $xml_file="1.xml";//指定所要讀取的xml文件,可以是url $filehandler = fopen($xml_file, "r");//打開文件 while ($data = fread($filehandler, 4096)) { xml_parse($parser, $data, feof($filehandler)); }//每次取出4096個字節(jié)進行處理 fclose($filehandler); xml_parser_free($parser);//關閉和釋放parser解析器 $name=false; $position=false; function startElement($parser_instance, $element_name, $attrs) //起始標簽事件的函數(shù) { global $name,$position; if($element_name=="NAME") { $name=true; $position=false; echo "名字:"; } if($element_name=="POSITION") {$name=false; $position=true; echo "職位:"; } } function characterData($parser_instance, $xml_data) //讀取數(shù)據(jù)時的函數(shù) { global $name,$position; if($position) echo $xml_data."<br />"; if($name) echo $xml_data."<br />"; } function endElement($parser_instance, $element_name) //結束標簽事件的函數(shù) { global $name,$position; $name=false; $position=false; } //xml數(shù)據(jù)讀取完畢 $htmlname=$id.".html";//$id可以自己定義 這里代表用戶傳來的id $htmlpath="archives/".$htmlname; //設置路徑變量 $content = ob_get_contents();//取得php頁面輸出的全部內(nèi)容 $fp = fopen($htmlpath, "w"); fwrite($fp, $content); fclose($fp); ?>
以上內(nèi)容就是給大家分享的php生成靜態(tài)html頁面的方法(2種方法),希望大家喜歡。
相關文章
laravel框架中控制器的創(chuàng)建和使用方法分析
這篇文章主要介紹了laravel框架中控制器的創(chuàng)建和使用方法,結合實例形式詳細分析了laravel框架控制器的原理、創(chuàng)建、使用方法及相關注意事項,需要的朋友可以參考下2019-11-11php中的filesystem文件系統(tǒng)函數(shù)介紹及使用示例
這篇文章主要介紹了php中的filesystem文件系統(tǒng)函數(shù)使用示例,需要的朋友可以參考下2014-02-02淺談PHP檢查數(shù)組中是否存在某個值 in_array 函數(shù)
下面小編就為大家?guī)硪黄獪\談PHP檢查數(shù)組中是否存在某個值 in_array 函數(shù)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-06-06PHP--用萬網(wǎng)的接口實現(xiàn)域名查詢功能
PHP用萬網(wǎng)的接口實現(xiàn)域名查詢功能,需要的朋友可以了解下2012-12-12