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

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

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

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

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

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

希望大虾们不要笑话

一般来说 用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变量里面,就是要显示的内容了
  7. $fp = fopen("archives/2005/05/19/0001.html", "w");
  8. fwrite($fp, $content);
  9. fclose($fp);
  10. ?>

第二种方法:利用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页面输出的全部内容
  5. $fp = fopen("archives/2005/05/19/0001.html", "w");
  6. fwrite($fp, $content);
  7. fclose($fp);
  8. ?>

我选用的第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页面输出的全部内容
  50. $fp = fopen($htmlpath, "w");
  51. fwrite($fp, $content);
  52. fclose($fp);
  53. ?>

转载:http://www.cnblogs.com/awinlei/archive/2013/03/04/2942962.html

用php生成静态html页面(通用2种方法)的更多相关文章

  1. 比较ASP生成静态HTML文件的几种方法

    将动态页面转换生成静态Html文件有许多好处,比如生成html网页有利于被搜索引擎收录(特别是对接受动态参数的页面).前台访问时,脱离了数据访问,减轻对数据库访问的压力,加快网页打开速度. 当然,凡事 ...

  2. 利用PHP的ob函数实现生成静态化页面

    之前用过一些开源的CMS管理系统,当时就很好奇后台中的生成HTML静态文件是怎么实现的.今天和同事讨论了下,没想到同事之前做过这类的生成静态页面的功能,果断向他请教了下. 经他讲解后,才知道其实生成静 ...

  3. JSP生成静态Html页面

    [转载]JSP生成静态Html页面 在网站项目中,为了访问速度加快,为了方便百度爬虫抓取网页的内容,需要把jsp的动态页面转为html静态页面.通常有2种常用的方式: 1.伪静态,使用URL Rewr ...

  4. Nginx实现404页面的几种方法【转】

    一个网站项目,肯定是避免不了404页面的,通常使用Nginx作为Web服务器时,有以下集中配置方式,一起来看看. 第一种:Nginx自己的错误页面 Nginx访问一个静态的html 页面,当这个页面没 ...

  5. Apacheserver自己定义404页面的两种方法以及.htaccess的重要命令总结

    Apacheserver自己定义404错误页面有两种方法: 第一种方法最简单,直接在Apache的httpd.conf下进行配置改动命令,改动的内容请參看.htaccess命令写法中的自己定义错误页面 ...

  6. Javascript刷新页面的几种方法

    Javascript刷新页面的几种方法: window.navigate(location)location.reload()location=locationlocation.assign(loca ...

  7. Javascript刷新页面的八种方法

    /** * Javascript刷新页面的八种方法 * 说明一下,jQuery没有发现刷新页面的方法. */ 1 history.go(0) 2 location.reload() 3 locatio ...

  8. 用php随机生成福彩双色球号码的2种方法

    不瞒您说,俺也是个双色球爱好者,经常买,但迟迟没有中过一等奖,哈哈.这里为大家介绍用php随机生成福彩双色球号码的二种方法,供朋友们学习参考.新的一年,祝大家中大奖,发大财. 方法一 复制代码代码如下 ...

  9. JS刷新页面的几种方法(转)

    Javascript刷新页面的几种方法: 1 history.go(0) 2 location.reload() 3 location=location 4 location.assign(locat ...

随机推荐

  1. python 函数小实例

    1.判断一个数字是否为素数: import math # -----------------判断一个数是否是素数------------------ def sushu(a): i=1 for i i ...

  2. log4j在javaWeb项目中的使用

    在前边的文章中对log4j的配置文件进行了说明,今天介绍如何在普通的javaWeb项目中使用log4j. 在日常的开发过程中,日志使用的很频繁,我们可以利用日志来跟踪程序的错误,程序运行时的输出参数等 ...

  3. GJM :Sql 各种语句 以及函数 [转载]

    版权声明:本文原创发表于 [请点击连接前往] ,未经作者同意必须保留此段声明!如有侵权请联系我删帖处理! 1.更改数据库的名称 2.表中有数据的情况下再添加列.删除列 3.在SQLServer 中各种 ...

  4. 删除 QQ 最新版右键菜单 通过QQ发送文件到手机

    64位:打开命令行执行: regsvr32 /u "C:\Program Files (x86)\Tencent\QQ\Bin\QQShellExt64.dll" 32位:打开命令 ...

  5. (原) 1.2 Zookeeper伪集群安装

    本文为原创文章,转载请注明出处,谢谢 Zookeeper伪集群安装 zookeeper单机安装配置可以查看 1.1 zookeeper单机安装 1.复制三份zookeeper,分别为zookeeper ...

  6. C#如何自定义DataGridViewColumn来显示TreeView

    我们可以自定义DataGridView的DataGridViewColumn来实现自定义的列,下面介绍一下如何通过扩展DataGridViewColumn来实现一个TreeViewColumn 1 T ...

  7. 向 Web 开发人员推荐35款 JavaScript 图形图表库

    图表是数据图形化的表示,通过形象的图表来展示数据,比如条形图,折线图,饼图等等.可视化图表可以帮助开发者更容易理解复杂的数据,提高生产的效率和 Web 应用和项目的可靠性. 在这篇文章中,我们收集了3 ...

  8. 【追寻javascript高手之路02】变量、作用域知多少?

    前言 本来想把这个与上篇博客写到一起的,但是考虑到是两个知识点还是分开算了,于是我们继续今天的学习吧. 基本类型与引用类型 ECMAScript的的变量有两种类型: 基本类型(值类型):简单数据段 引 ...

  9. javscript闭包的准备工作 -- 作用域与作用域链

    作用域是JavaScript最重要的概念之一,想要学好JavaScript就需要理解JavaScript作用域和作用域链的工作原理.今天这篇文章对JavaScript作用域和作用域链作简单的介绍,希望 ...

  10. 正则中关于修饰符g以及exec和match区别的一个小demo

    代码: 输出结果 补充: reg.lastIndex:下一次正则捕获的开始查找的索引位置 ->正则的懒惰性就是因为默认情况下lastIndex值都是0,我们不管执行几次exec,都是从字符串的开 ...