使用PHP实现生成HTML静态页面
从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*from2carsell");
$totle=mysql_num_rows($result);
$pagelist=$_GET[t];
if($_GET[t]==''){
$pagelist='200';
}else{
$pagelist=$_GET[t];
}
$pager=newPager($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*from2carsellORDERBYidDESClimit$limitFrom,$pagelist");
?>
<center><divstyle="font-size:14px;"><b>第<fontcolor=red><?echo$aa?></font>次页面生成中..<?echo$datastat?></b></div><br>
<?
//php生成静态页面
print"<center><textareaname=textareaclass=textareastyle='width:520px;height:455px'>";
while($datauser=mysql_fetch_array($result)){
$iid=$datauser[id];
$html=file_get_contents("/moban.php?id=".$iid."");
$sql="select*from2carsellwhereid=$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>
<divstyle="font-size=12px"><?echo$datastat.""?></div><br><br>
<?
$aa=$aa+1;
if($aa>$bb){
echo'<fontcolor=blue>恭喜,所有页面生成完毕!</font>';
echo"<script>alert('所有文档生成/更新完毕!')</script>";
}else{
echo"<Script>window.location='make.php?t=$pagelist&pg=$aa';</script>";
}
?>
看完实例,我们接着来分析分析
一般来说用php转换输出html页面有两种办法引用大虾的文章如下:
第一种:利用模板。目前PHP的模板可以说是很多了,有功能强大的smarty,还有简单易用的smarttemplate等。它们每一种模板,都有一个获取输出内容的函数。我们生成静态页面的方法,就是利用了这个函数。用这个方法的优点是,代码比较清晰,可读性好。
这里我用smarty做例子,说明如何生成静态页:
<?php
require("smarty/Smarty.class.php");
$t=newSmarty;
$t->assign("title","HelloWorld!");
$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"HelloWorld!";
$content=ob_get_contents();//取得php页面输出的全部内容
$fp=fopen("archives/2005/05/19/0001.html","w");
fwrite($fp,$content);
fclose($fp);
?>
我选用的第2种方法也就是用ob系列的函数
我刚开始看这个的时候有点不太明白后来才知道ob是outputbuffering的意思也就是输出缓存
当你准备输出的时候所有的数据都保存在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;
functionstartElement($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"职位:";
}
}
functioncharacterData($parser_instance,$xml_data)//读取数据时的函数
{
global$name,$position;
if($position)
echo$xml_data."<br/>";
if($name)
echo$xml_data."<br/>";
}
functionendElement($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);
?>