当前位置:Gxlcms > PHP教程 > 使用PHP实现生成HTML静态页面,php静态页面_PHP教程

使用PHP实现生成HTML静态页面,php静态页面_PHP教程

时间:2021-07-01 10:21:17 帮助过:5人阅读

使用PHP实现生成HTML静态页面,php静态页面


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

完整实例:

  1. <?php
  2. if($_GET[pg]==''){
  3. $aa=1;
  4. }else{
  5. $aa=$_GET[pg];
  6. }
  7. include("admin/conn.php");
  8. require_once("page.php");
  9. $result=mysql_query("select * from 2carsell ");
  10. $totle=mysql_num_rows($result);
  11. $pagelist = $_GET[t];
  12. if($_GET[t]==''){
  13. $pagelist='200';
  14. }else{
  15. $pagelist=$_GET[t];
  16. }
  17. $pager = new Pager($totle,$pagelist);
  18. $datastat=" 共 <b>".$pager->countall."</b> 条,每次生成 <b>".$pager->countlist."</b> 条,共需生成 <b>".$pager->page."</b> 次";//数据统计
  19. $bb=$pager->page;
  20. $pagenav=$pager->backstr.$pager->thestr.$pager->nextstr;
  21. $limitFrom = $pagelist*($pager->pg-1);
  22. $result=mysql_query("select * from 2carsell ORDER BY id DESC limit $limitFrom,$pagelist");
  23. ?>
  24. <center><b>第 <font color="red"><?echo $aa?></font> 次页面生成中..<? echo $datastat?></b><br>
  25. <?
  26. //php生成静态页面
  27. print "<center><textarea name="textarea" class="textarea" style="width:520px;height:455px">";
  28. while($datauser=mysql_fetch_array($result)){
  29. $iid=$datauser[id];
  30. $html = file_get_contents("/moban.php?id=".$iid."");
  31. $sql="select * from 2carsell where id=$iid";
  32. $data=mysql_fetch_array(mysql_query($sql));
  33. $path=date("Ym",$data[PutDate]);
  34. $testdir="html/".$path;
  35. if(file_exists ($testdir)):
  36. else:
  37. mkdir ($testdir, 0777);
  38. echo "目录".$testdir."创建成功!<br>";
  39. endif;
  40. $filename = "html/$path/sell_$iid.html";
  41. // 使用写入模式打开$filename
  42. if (!$handle = fopen($filename, 'w')) {
  43. print "不能打开文件 $filename";
  44. exit;
  45. }
  46. if (is_writable($filename)) {
  47. // 将$html写入到我们打开的文件中。
  48. if (!fwrite($handle, $html)) {
  49. print "不能写入到文件 $filename";
  50. exit;
  51. }
  52. print "文件 $filename 更新成功!\n\r";
  53. fclose($handle);
  54. } else {
  55. print "文件 $filename 不可写";
  56. }
  57. ?>
  58. <? }?>
  59. </textarea>
  60. <br><br>
  61. <? echo $datastat." "?><br><br>
  62. <?
  63. $aa=$aa+1;
  64. if($aa>$bb){
  65. echo '<font color="blue">恭喜,所有页面生成完毕!</font>';
  66. echo "";
  67. }else{
  68. echo "";
  69. }
  70. ?>
  71. </center></center>

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

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

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

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

  1. <?php
  2. require("smarty/Smarty.class.php");
  3. $t = new Smarty;
  4. $t->assign("title","Hello World!");
  5. $content = $t->fetch("templates/index.htm");
  6. //这里的 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(),道理一样的。

  1. <?php
  2. ob_start();
  3. echo "Hello World!";
  4. $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数据的一个简单例子

  1. <?php
  2. ob_start();//打开浏览器缓存
  3. //下面是读取xml数据
  4. $parser = xml_parser_create(); //创建一个parser编辑器
  5. xml_set_element_handler($parser, "startElement", "endElement");//设立标签触发时的相应函数 这里分别为startElement和endElenment
  6. xml_set_character_data_handler($parser, "characterData");//设立数据读取时的相应函数
  7. $xml_file="1.xml";//指定所要读取的xml文件,可以是url
  8. $filehandler = fopen($xml_file, "r");//打开文件
  9. while ($data = fread($filehandler, 4096))
  10. {
  11. xml_parse($parser, $data, feof($filehandler));
  12. }//每次取出4096个字节进行处理
  13. fclose($filehandler);
  14. xml_parser_free($parser);//关闭和释放parser解析器
  15. $name=false;
  16. $position=false;
  17. function startElement($parser_instance, $element_name, $attrs) //起始标签事件的函数
  18. {
  19. global $name,$position;
  20. if($element_name=="NAME")
  21. {
  22. $name=true;
  23. $position=false;
  24. echo "名字:";
  25. }
  26. if($element_name=="POSITION")
  27. {$name=false;
  28. $position=true;
  29. echo "职位:";
  30. }
  31. }
  32. function characterData($parser_instance, $xml_data) //读取数据时的函数
  33. {
  34. global $name,$position;
  35. if($position)
  36. echo $xml_data."<br>";
  37. if($name)
  38. echo $xml_data."<br>";
  39. }
  40. function endElement($parser_instance, $element_name) //结束标签事件的函数
  41. {
  42. global $name,$position;
  43. $name=false;
  44. $position=false;
  45. }
  46. //xml数据读取完毕
  47. $htmlname=$id.".html";//$id可以自己定义 这里代表用户传来的id
  48. $htmlpath="archives/".$htmlname; //设置路径变量
  49. $content = ob_get_contents();//取得php页面
输出的全部内容 $fp = fopen($htmlpath, "w"); fwrite($fp, $content); fclose($fp); ?>

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/1073133.htmlTechArticle使用PHP实现生成HTML静态页面,php静态页面 从PHP生成HTML静态页面并存储到以年份和月份为名称创建的目录。 读取全部数据批量生成,全部生...

人气教程排行