用php生成靜態html頁面 由於每次用戶點擊動態連接的時候都會對服務器發送數據查詢的要求php
對於一個訪問量可能達百萬千萬級別的網站來講 這無疑是服務器一個大大的負擔html
因此把動態數據轉換成靜態html頁面就成了節省人力物力的首選web
由於此前沒有相應的經驗 剛開始的時候以爲這個技術很神祕數據庫
但在看了一些例子之後發現並非那麼複雜(不過網上的資料並非特別詳細)數組
通過一個上午加中下午的試驗 終於把該作的任務完成了 下面是一些心得和一個簡單的例子瀏覽器
但願大蝦們不要笑話緩存
通常來講 用php轉換輸出html頁面有兩種辦法 引用大蝦的文章以下:安全
第一種:利用模板。目前PHP的模板能夠說是不少了,有功能強大的smarty,還有簡單易用的smarttemplate等。它們每一種模板,都有一個獲取輸出內容的函數。咱們生成靜態頁面的方法,就是利用了這個函數。用這個方法的優勢是,代碼比較清晰,可讀性好。服務器
這裏我用smarty作例子,說明如何生成靜態頁:app
<?php require("smarty/Smarty.class.php"); $t = new Smarty; $t->assign("title","Hello World!"); $content = $t->fetch("templates/index.htm"); //這裏的 fetch() 就是獲取輸出內容的函數,如今$content變量裏面,就是要顯示的內容了 $fp = fopen("archives/2005/05/19/0001.html", "w"); fwrite($fp, $content); fclose($fp); ?>
第二種方法:利用ob系列的函數。這裏用到的函數主要是 ob_start(), ob_end_flush(), ob_get_content(),其中ob_start()是打開瀏覽器緩衝區的意思,打開緩衝後,全部來自PHP程序的非文件頭信息均不會發送,而是保存在內部緩衝區,直到你使用了ob_end_flush().而這裏最重要的一個函數,就是ob_get_contents(),這個函數的做用是獲取緩衝區的內容,至關於上面的那個fetch(),道理同樣的。
<?php ob_start(); echo "Hello World!"; $content = ob_get_contents();//取得php頁面輸出的所有內容 $fp = fopen("archives/2005/05/19/0001.html", "w"); fwrite($fp, $content); fclose($fp); ?>
我選用的第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數據的一個簡單例子
<?php ob_start();//打開瀏覽器緩存 //下面是讀取xml數據 $parser = xml_parser_create(); //建立一個parser編輯器 xml_set_element_handler($parser, "startElement", "endElement");//設立標籤觸發時的相應函數 這裏分別爲startElement和endElenment xml_set_character_data_handler($parser, "characterData");//設立數據讀取時的相應函數 $xml_file="1.xml";//指定所要讀取的xml文件,能夠是url $filehandler = fopen($xml_file, "r");//打開文件 while ($data = fread($filehandler, 4096)) { xml_parse($parser, $data, feof($filehandler)); }//每次取出4096個字節進行處理 fclose($filehandler); xml_parser_free($parser);//關閉和釋放parser解析器 $name=false; $position=false; function startElement($parser_instance, $element_name, $attrs) //起始標籤事件的函數 { 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) //讀取數據時的函數 { global $name,$position; if($position) echo $xml_data."<br />"; if($name) echo $xml_data."<br />"; } function endElement($parser_instance, $element_name) //結束標籤事件的函數 { global $name,$position; $name=false; $position=false; } //xml數據讀取完畢 $htmlname=$id.".html";//$id能夠本身定義 這裏表明用戶傳來的id $htmlpath="archives/".$htmlname; //設置路徑變量 $content = ob_get_contents();//取得php頁面輸出的所有內容 $fp = fopen($htmlpath, "w"); fwrite($fp, $content); fclose($fp); ?>
Related posts:
一個用PHP讀取XML數據的簡單例子 今天工做上碰到一個問題 因爲咱們的項目數據太少 因此須要從web search那邊借調數據 他們只給咱們提供了一個xml的接口 所以咱們須要把xml的數據轉化成html呈現給你們 因爲項目是基於php的 因此就摒棄了用js來讀取xml選擇了繼續使用php 不過我之前歷來沒有作過此類的嘗試 因此找了不少網上資料... 用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"))//判斷文件是否存在並打開... PHP優秀的文件訪問功能 這些天和php的親密接觸讓我愈來愈喜歡這個語言OS的語言就是好 不少人爲它寫函數 綜合起你們的力量這樣的語言是最有發展前途的今天和你們介紹一下php的文件訪問功能: php的文件訪問功能很是強大,固然強大並不意味着難,在互聯網這個領域,越強大表明越簡單,由於很好用。在php裏面,涉及到file訪問的函數有file()、fopen()、readfile()和get_file_content()等等。這裏跟你們介紹最簡單實用的file()函數,其餘的函數運用其實都差很少,你們能夠去查php手冊。 下面是php手冊當中對file()函數的簡單介紹: 引用內容 file (PHP 3, PHP... 分享一個php遍歷目錄的函數 工做上有須要,本身寫了一個,代碼以下: function outputDirFile($dir) { if ($handle = opendir($dir)) { while (false... thebeststuff圖集的生成方法 以前發表的一個文章引起了一些很激烈的討論,事實上你們誤解了個人意思,我最想知道的是它的生成流程,而不是具體技術細節,可是無論如何,在這裏謝謝各位熱心留言的朋友了,這個週末在家我利用空暇時間把本身的一些想法用php表達了出來,初步成功地實現了這種效果,如今放上來和你們分享,下面是我利用GD隨機挑選位置生成的圖片: 要解決這個問題的關鍵在於圖片位置的選擇,具體來講分爲兩步: 1. 隨機選擇一個位置(x、y座標); 2. 根據圖片的寬度、高度以及x、y座標判斷此位置是否能夠放圖; 第一個步驟很好作,先用GD生成一張空白圖片(好比300*100),而後在空白圖中隨機選一個座標用來放置讀入的新圖片便可; 第二步稍微複雜一點,由於要判斷以前的座標是否可以放置新圖片,這裏須要對以前已經有圖片的位置作一個信息保存,以方便去逐一對比,我在這裏使用了一個二維數組來保存以前圖片的位置信息,相似於數據庫中的一組數據,第一維是圖片,第二維是圖片座標信息,包括x一、y一、x二、y2四個組成部分;有了這個數組,咱們就能夠在程序中循環判斷哪一個區域對於當前圖片來講是可用的,而後遞歸調用GD的圖片copy生成函數就能夠了。 下面是個人php代碼: 下載:...