Chinaunix首页 | 论坛 | 博客
  • 博客访问: 106400
  • 博文数量: 36
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 330
  • 用 户 组: 普通用户
  • 注册时间: 2014-08-18 23:16
文章分类
文章存档

2016年(7)

2015年(20)

2014年(9)

我的朋友

分类: PHP

2014-12-02 19:30:32

因为每次用户点击动态链接的时候都会对服务器发送数据查询的要求

对于一个访问量可能达百万千万级别的网站来说 这无疑是服务器一个大大的负担

所以把动态数据转换成静态html页面就成了节省人力物力的首选

因为此前没有相应的经验 刚开始的时候觉得这个技术很神秘

但在看了一些例子以后发现并不是那么复杂(不过网上的资料并不是特别详细)

经过一个上午加中下午的试验 终于把该做的任务完成了 下面是一些心得和一个简单的例子

希望大虾们不要笑话

 

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

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

 

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

 

  1. require("smarty/Smarty.class.php");
  2. $t = new Smarty;
  3. $t->assign("title","Hello World!");
  4. $content = $t->fetch("templates/index.htm");
  5. //这里的 fetch() 就是获取输出内容的函数,现在$content变量里面,就是要显示的内容了
  6. $fp = fopen("archives/2005/05/19/0001.html", "w");
  7. fwrite($fp, $content);
  8. fclose($fp);
  9. ?>

 

 

 

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

 

 

  1. ob_start();
  2. echo "Hello World!";
  3. $content = ob_get_contents();//取得php页面输出的全部内容
  4. $fp = fopen("archives/2005/05/19/0001.html", "w");
  5. fwrite($fp, $content);
  6. fclose($fp);
  7. ?>

 

我选用的第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. ob_start();//打开浏览器缓存
  2.  
  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.  
  10.  
  11. while ($data = fread($filehandler, 4096)) 
  12. {
  13. xml_parse($parser, $data, feof($filehandler));
  14. }//每次取出4096个字节进行处理
  15.  
  16. fclose($filehandler);
  17. xml_parser_free($parser);//关闭和释放parser解析器
  18.  
  19.  
  20. $name=false;
  21. $position=false;
  22. function startElement($parser_instance, $element_name, $attrs) //起始标签事件的函数
  23. {
  24. global $name,$position;
  25. if($element_name=="NAME")
  26. {
  27. $name=true;
  28. $position=false;
  29. echo "名字:";
  30. }
  31. if($element_name=="POSITION")
  32. {$name=false;
  33. $position=true;
  34. echo "职位:";
  35. }
  36. }
  37.  
  38. function characterData($parser_instance, $xml_data) //读取数据时的函数
  39. {
  40. global $name,$position;
  41. if($position)
  42. echo $xml_data."
    ";
  43. if($name)
  44. echo $xml_data."
    ";
  45. }
  46.  
  47. function endElement($parser_instance, $element_name) //结束标签事件的函数
  48. {
  49. global $name,$position;
  50. $name=false;
  51. $position=false;
  52. }
  53. //xml数据读取完毕
  54.  
  55. $htmlname=$id.".html";//$id可以自己定义 这里代表用户传来的id
  56. $htmlpath="archives/".$htmlname; //设置路径变量
  57. $content = ob_get_contents();//取得php页面输出的全部内容
  58. $fp = fopen($htmlpath, "w");
  59. fwrite($fp, $content);
  60. fclose($fp);
  61. ?>
阅读(1311) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~