当你准备输出的时候 所有的数据都保存在ob里面 服务器解析完php以后
把所有要输出到客户端的html代码都存放在ob里面 如果我们要输出html静态页面
只要把缓存取出来写入一个html页面即可

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

这里用到了几个函数 由于我初学php 很多函数我还不了解 所以这里也说明一下
希望可以帮助大家

说明:原动态地址为 moban.php?id=1 ,生成后地址为
html/200808/sell_1.html 。page.php为分页程序,本博客中有发布。

从PHP生成HTML静态页面并存储到以年份和月份为名称创建的目录。

“r+” 读写方式打开,将文件指针指向文件头。

“r” 只读方式打开,将文件指针指向文件头。

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

ob_start():开始“捕捉”缓存 也就是从这里开始 打开浏览器的缓存

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

";ifecho $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;fwrite;fclose;?>

“w”
写入方式打开,将文件指针指向文件头并将文件大小截为零。如果文件不存在则尝试创建之。

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

由于我要转换的html文件非常多 可能有几百个
所以这里不能静态指定fopen的路径 大家可以设置一个路径变量
里面可以保存用户传来的id等信息 方便进行html文件命名
下面是我结合上次php读取xml数据的一个简单例子

fwrite 写入文件

读取全部数据批量生成,全部生成后弹出提示。

“w+”
读写方式打开,将文件指针指向文件头并将文件大小截为零。如果文件不存在则尝试创建之。

ob_get_content():读取缓存内容

(出于众所周知的原因,涉及到数据库的数据字段名称做了改动,并且为了代码明晰去掉了参数过滤的部分)

ob_end_flush():关闭浏览器缓存

我刚开始看这个的时候有点不太明白 后来才知道ob是output buffering的意思
也就是输出缓存

页面使用方式,将本代码保存为make.php,使用方法为浏览器访问
make.php?t=数量&pg=页面;例如
make.php?t=300&pg=2,即每次生成300条数据,从数据列表第2页开始生成,即跳过前面300条。如果不加任何参数,直接访问make.php,则默认每次生成200条,从第一页开始生成。

所以原理其实是很简单的

我选用的第2种方法 也就是用ob系列的函数

".$pager->countall." 条,每次生成 ".$pager->countlist." 条,共需生成 ".$pager->page." 次";//数据统计 $bb=$pager->page; $pagenav=$pager->backstr.$pager->thestr.$pager->nextstr; $limitFrom = $pagelist*; $result=mysql_query("select * from 2carsell ORDER BY id DESC limit $limitFrom,$pagelist"); ?> 第  次页面生成中..
 "; while($datauser=mysql_fetch_array{ $iid=$datauser[id]; $html = file_get_contents; $sql="select * from 2carsell where id=$iid"; $data=mysql_fetch_array; $path=date; $testdir="html/".$path; if(file_exists : else: mkdir ; echo "目录".$testdir."创建成功!
"; endif; $filename = "html/$path/sell_$iid.html"; // 使用写入模式打开$filename if (!$handle = fopen { print "不能打开文件 $filename"; exit; } if (is_writable { // 将$html写入到我们打开的文件中。 if (!fwrite { print "不能写入到文件 $filename"; exit; } print "文件 $filename 更新成功!nr"; fclose; } else { print "文件 $filename 不可写"; } ?>   



 恭喜,所有页面生成完毕!'; echo "alert"; }else{ echo " window.location='make.php?t=$pagelist&pg=$aa'; "; } ?> 

fclose() 关闭文件

assign("title","Hello World!");$content = $t->fetch("templates/index.htm");//这里的 fetch() 就是获取输出内容的函数,现在$content变量里面,就是要显示的内容了$fp = fopen("archives/2005/05/19/0001.html", "w");fwrite;fclose;?>

fopen打开文件 这个函数的打开模式有好几种 下面介绍几种主要的模式:

第二种方法:利用ob系列的函数。这里用到的函数主要是 ob_start,
ob_get_content是打开浏览器缓冲区的意思,打开缓冲后,所有来自PHP程序的非文件头信息均不会发送,而是保存在内部缓冲区,直到你使用了ob_end_flush().而这里最重要的一个函数,就是ob_get_contents(),这个函数的作用是获取缓冲区的内容,相当于上面的那个fetch(),道理一样的。

可指定批次生成数量,建议不超过800,否则执行速度会有问题。

发表评论

电子邮件地址不会被公开。 必填项已用*标注