因为每次用户点击动态链接的时候都会对服务器发送数据查询的要求
对于一个访问量可能达百万千万级别的网站来说 这无疑是服务器一个大大的负担
所以把动态数据转换成静态html页面就成了节省人力物力的首选
因为此前没有相应的经验 刚开始的时候觉得这个技术很神秘
但在看了一些例子以后发现并不是那么复杂(不过网上的资料并不是特别详细)
经过一个上午加中下午的试验 终于把该做的任务完成了 下面是一些心得和一个简单的例子
希望大虾们不要笑话
一般来说 用php转换输出html页面有两种办法 引用大虾的文章如下:
第一种:利用模板。目前PHP的模板可以说是很多了,有功能强大的smarty,还有简单易用的smarttemplate等。它们每一种模板,都有一个获取输出内容的函数。我们生成静态页面的方法,就是利用了这个函数。用这个方法的优点是,代码比较清晰,可读性好。
这里我用smarty做例子,说明如何生成静态页:
- <?php
- require("smarty/Smarty.class.php");
- $t = new Smarty;
- $t->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(),道理一样的。
- <?php
- ob_start();
- echo "Hello World!";
- $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数据的一个简单例子
- <?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."<br />";
- if($name)
- echo $xml_data."<br />";
- }
- 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, "w");
- fwrite($fp, $content);
- fclose($fp);
- ?>
Related posts:
- 一个用PHP读取XML数据的简单例子 今天工作上碰到一个问题 由于我们的项目数据太少 所以需要从web search那边借调数据 他们只给我们提供了一个xml的接口 因此我们需要把xml的数据转化成html呈现给大家 由于项目是基于php的 所以就摒弃了用js来读取xml选择了继续使用php 不过我以前从来没有做过此类的尝试 所以找了很多网上资料...
- 用php实现文件安全下载 最近在研究php实现文件下载的问题,按道理来说,一般的文件下载很简单,建立一个链接指向到目标文件就可以了,但是这样就直接暴露了文件所在路径,给盗链者打开了大门,并且可能会有安全隐患,一般来说,要实现安全的文件下载,在php下一般是利用header和fread这么来做的: 第一步 假设你要下载的是一个torrent的文件,那么先建立一个动态php文件,用户点击下载文件的时候直接链接到这个php并传回与文件位置相关的参数以帮助这个php能从数据库中取出文件所在的真实位置;这样做的另外一个好处是,可以通过这个php来对下载进行统计计数;这个过程并不难,所以就不写代码了,主要是对数据库的查询,假设文件的真实位置是$fileAdd,文件名为$fileName; 第二步 得到文件所在的真实位置以后,有人会用header的location直接重定向到这个文件,但是这样仍然是不安全的,因为某些下载软件还是可以通过重定向分析获得你的文件位置信息,因此需要用另外一种方法,就是php的文件处理API函数,这里主要是运用fread函数把文件直接吐给浏览器,让浏览器提示用户下载,所有的这些处理都是在服务器端完成的,因此用户是不会知道文件具体位置信息的,具体代码如下: Header("content-type:application/octet-stream"); Header("content-disposition:attatchment;filename:".$fileName.".torrent"); if(file_exists($fileAdd) && $file=fopen($fileAdd,"r"))//判断文件是否存在并打开...
- PHP优秀的文件访问功能 这些天和php的亲密接触让我越来越喜欢这个语言OS的语言就是好 很多人为它写函数 综合起大家的力量这样的语言是最有发展前途的今天和大家介绍一下php的文件访问功能: php的文件访问功能非常强大,当然强大并不意味着难,在互联网这个领域,越强大代表越简单,因为很好用。在php里面,涉及到file访问的函数有file()、fopen()、readfile()和get_file_content()等等。这里跟大家介绍最简单实用的file()函数,其他的函数运用其实都差不多,大家可以去查php手册。 下面是php手册当中对file()函数的简单介绍: 引用内容 file (PHP 3, PHP...
- 分享一个php遍历目录的函数 工作上有需要,自己写了一个,代码如下: function outputDirFile($dir) { if ($handle = opendir($dir)) { while (false...
- thebeststuff图集的生成方法 之前发表的一个文章引发了一些很激烈的讨论,事实上大家误解了我的意思,我最想知道的是它的生成流程,而不是具体技术细节,但是不管如何,在这里谢谢各位热心留言的朋友了,这个周末在家我利用空暇时间把自己的一些想法用php表达了出来,初步成功地实现了这种效果,现在放上来和大家分享,下面是我利用GD随机挑选位置生成的图片: 要解决这个问题的关键在于图片位置的选择,具体来说分为两步: 1. 随机选择一个位置(x、y坐标); 2. 根据图片的宽度、高度以及x、y坐标判断此位置是否可以放图; 第一个步骤很好做,先用GD生成一张空白图片(比如300*100),然后在空白图中随机选一个坐标用来放置读入的新图片即可; 第二步稍微复杂一点,因为要判断之前的坐标是否能够放置新图片,这里需要对之前已经有图片的位置做一个信息保存,以方便去逐一对比,我在这里使用了一个二维数组来保存之前图片的位置信息,类似于数据库中的一组数据,第一维是图片,第二维是图片坐标信息,包括x1、y1、x2、y2四个组成部分;有了这个数组,我们就可以在程序中循环判断哪个区域对于当前图片来说是可用的,然后递归调用GD的图片copy生成函数就可以了。 下面是我的php代码: 下载:...
请发表评论