欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用PHP實現(xiàn)生成HTML靜態(tài)頁面

 更新時間:2015年11月18日 08:49:39   投稿:hebedich  
在PHP網(wǎng)站開發(fā)中為了網(wǎng)站推廣和SEO等需要,需要對網(wǎng)站進行全站或局部靜態(tài)化處理,PHP生成靜態(tài)HTML頁面有多種方法,比如利用PHP模板、緩存等實現(xiàn)頁面靜態(tài)化,今天就以PHP實例教程形式討論PHP生成靜態(tài)頁面的方法。

從PHP生成HTML靜態(tài)頁面并存儲到以年份和月份為名稱創(chuàng)建的目錄。

讀取全部數(shù)據(jù)批量生成,全部生成后彈出提示。

可指定批次生成數(shù)量,建議不超過800,否則執(zhí)行速度會有問題。

(出于眾所周知的原因,涉及到數(shù)據(jù)庫的數(shù)據(jù)字段名稱做了改動,并且為了代碼明晰去掉了參數(shù)過濾的部分)

 說明:原動態(tài)地址為 moban.php?id=1 ,生成后地址為 html/200808/sell_1.html 。page.php為分頁程序,本博客中有發(fā)布。

頁面使用方式,將本代碼保存為make.php,使用方法為瀏覽器訪問 make.php?t=數(shù)量&pg=頁面;例如 make.php?t=300&pg=2,即每次生成300條數(shù)據(jù),從數(shù)據(jù)列表第2頁開始生成,即跳過前面300條。如果不加任何參數(shù),直接訪問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> 次";//數(shù)據(jù)統(tǒng)計 
$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生成靜態(tài)頁面 
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."創(chuàng)建成功!<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等。它們每一種模板,都有一個獲取輸出內容的函數(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() 就是獲取輸出內容的函數(shù),現(xiàn)在$content變量里面,就是要顯示的內容了
$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ā)送,而是保存在內部緩沖區(qū),直到你使用了ob_end_flush().而這里最重要的一個函數(shù),就是ob_get_contents(),這個函數(shù)的作用是獲取緩沖區(qū)的內容,相當于上面的那個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系列的函數(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():讀取緩存內容

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

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

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

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

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

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

fclose() 關閉文件

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

<?php
ob_start();//打開瀏覽器緩存
 
//下面是讀取xml數(shù)據(jù)
$parser = xml_parser_cr&#101;ate(); //創(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頁面輸出的全部內容
$fp = fopen($htmlpath, "w");
fwrite($fp, $content);
fclose($fp);
?>

相關文章

最新評論