微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用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条,从第一页开始生成

完整实例:

rush:PHP;"> 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=" 共 ".$pager->countall." 条,每次生成 ".$pager->countlist." 条,共需生成 ".$pager->page." 次";//数据统计 $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"); ?>
页面生成中..

PHP生成静态页面 print "




$bb){ echo '恭喜,所有页面生成完毕!'; echo ""; }else{ echo ""; } ?>

看完实例,我们接着来分析分析

一般来说 用PHP转换输出html页面有两种办法 引用大虾的文章如下:

第一种:利用模板。

目前PHP的模板可以说是很多了,有功能强大的smarty,还有简单易用的smarttemplate等。它们每一种模板,都有一个获取输出内容函数。我们生成静态页面方法,就是利用了这个函数。用这个方法的优点是,代码比较清晰,可读性好。

这里我用smarty做例子,说明如何生成静态页:

rush:PHP;"> 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(),道理一样的。

rush:PHP;">

我选用的第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数据的一个简单例子

rush:PHP;"> 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."
";
if($name)
echo $xml_data."
";
}

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,$content);
fclose($fp);
?>

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐