使用PHP實現產生HTML靜態頁面_php技巧

來源:互聯網
上載者:User

從PHP產生HTML靜態頁面並儲存到以年份和月份為名稱建立的目錄。

讀取全部資料批量產生,全部產生後彈出提示。

可指定批次產生數量,建議不超過800,否則執行速度會有問題。

(出於眾所周知的原因,涉及到資料庫的資料欄位名稱做了改動,並且為了代碼明晰去掉了參數過濾的部分)

 說明:原動態地址為 moban.php?id=1 ,產生後地址為 html/200808/sell_1.html 。page.php為分頁程式,本部落格中有發布。

頁面使用方式,將本代碼儲存為make.php,使用方法為瀏覽器訪問 make.php?t=數量&pg=頁面;例如 make.php?t=300&pg=2,即每次產生300條資料,從資料列表第2頁開始產生,即跳過前面300條。如果不加任何參數,直接存取make.php,則預設每次產生200條,從第一頁開始產生。

完整執行個體:

<?php if($_GET[pg]==''){ $aa=1; }else{ $aa=$_GET[pg]; } include("admin/conn.php"); require_once("page.php"); $result=mysql_query("select * from 2carsell "); $totle=mysql_num_rows($result); $pagelist = $_GET[t]; if($_GET[t]==''){ $pagelist='200'; }else{ $pagelist=$_GET[t]; } $pager = new Pager($totle,$pagelist); $datastat=" 共 <b>".$pager->countall."</b> 條,每次產生 <b>".$pager->countlist."</b> 條,共需產生 <b>".$pager->page."</b> 次";//資料統計 $bb=$pager->page; $pagenav=$pager->backstr.$pager->thestr.$pager->nextstr; $limitFrom = $pagelist*($pager->pg-1); $result=mysql_query("select * from 2carsell ORDER BY id DESC limit $limitFrom,$pagelist"); ?> <center><div style="font-size:14px;"><b>第 <font color=red><?echo $aa?></font > 次頁面產生中..<? echo $datastat?></b></div><br> <? //php產生靜態頁面 print "<center><textarea name=textarea class=textarea style='width:520px;height:455px'>"; while($datauser=mysql_fetch_array($result)){   $iid=$datauser[id]; $html = file_get_contents("/moban.php?id=".$iid.""); $sql="select * from 2carsell where id=$iid"; $data=mysql_fetch_array(mysql_query($sql)); $path=date("Ym",$data[PutDate]); $testdir="html/".$path; if(file_exists ($testdir)): else: mkdir ($testdir, 0777); echo "目錄".$testdir."建立成功!<br>"; endif;   $filename = "html/$path/sell_$iid.html";   // 使用寫入模式開啟$filename if (!$handle = fopen($filename, 'w')) { print "不能開啟檔案 $filename"; exit; }   if (is_writable($filename)) {   // 將$html寫入到我們開啟的檔案中。 if (!fwrite($handle, $html)) { print "不能寫入到檔案 $filename"; exit; }   print "檔案 $filename 更新成功!\n\r";   fclose($handle);   } else { print "檔案 $filename 不可寫"; } ?> <? }?> </textarea> <br><br> <div style="font-size=12px"><? echo $datastat." "?></div><br><br> <? $aa=$aa+1; if($aa>$bb){ echo '<font color=blue>恭喜,所有頁面產生完畢!</font>'; echo "<script>alert('所有文檔產生/更新完畢!')</script>"; }else{ echo "<Script> window.location='make.php?t=$pagelist&pg=$aa'; </script>"; } ?> 

看完執行個體,我們接著來分析分析

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

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

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

<?phprequire("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(),道理一樣的。

<?phpob_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資料的一個簡單例子

<?phpob_start();//開啟瀏覽器緩衝 //下面是讀取xml資料$parser = xml_parser_create(); //建立一個parser編輯器xml_set_element_handler($parser, "startElement", "endElement");//設立標籤觸發時的相應函數 這裡分別為startElement和endElenmentxml_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);?>

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.