当前位置: 首页 > 图文教程 > 网络编程 > PHP > 使用PHP程序加速探索之缓存输出

PHP
php 多线程上下文中安全写文件实现代码
PHP类的使用 实例代码讲解
用php实现让页面只能被百度gogole蜘蛛访问的方法
php 学习笔记
PHP编程过程中需要了解的this,self,parent的区别
php 操作excel文件的方法小结
使用PHP获取网络文件的实现代码
PHP 巧用数组降低程序的时间复杂度
php下将XML转换为数组
php 文件上传代码(限制jpg文件)
php 无极分类(递归)实现代码
PHP 采集获取指定网址的内容
PHP 将图片按创建时间进行分类存储的实现代码
PHP 存储文本换行实现方法
PHP 批量更新网页内容实现代码
用PHP查询搜索引擎排名位置的代码
用php实现的获取网页中的图片并保存到本地的代码
php实现首页链接查询 友情链接检查的代码
处理php自动反斜杠的函数代码
php实现的遍历文件夹下所有文件,编辑删除

使用PHP程序加速探索之缓存输出


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 37 ::
收藏到网摘: n/a

内容缓存输出 PEAR cache

  接下来我们开始探索更常用的缓存技术,这也是本文的重点部份。首先我们使用PEAR中的cache包。PEAR可以将内容缓存于文件,数据库或者内存中,我们以文件为例。

  下面是一个没有使用缓存的PHP小程序:

  pear_content_cache1.php
  

<?php
 echo "这是内容。<P>";
 echo "当前时间是" . date('M-d-Y H:i:s A', time()) . "<BR>";
?>

  上面这个程序非常简单,现在我们为其加上缓存。

  pear_content_cache2.php

<?php
 require_once 'Cache/Output.php';

 //设置缓存目录,必须是可写的
 $cacheDir = './pear_cache';
 $cache = new Cache_Output('file',array('cache_dir' => $cacheDir));

 //如果nocache变量为空,使用缓存中的内容
 //如果想获得最新的内容,就要赋值给nocache变量
 if (empty($_REQUEST['nocache']))
 {
  // 建立一个独一的cache标识
  // 请求+Cookie信息
  $cache_id = $cache->generateID(array('url' => $_REQUEST,'post' =>$_POST,'cookies' => $HTTP_COOKIE_VARS));
 }
 else
 {
  //想获得最新的内容,ID为空
  $cache_id = null;
 }

 //看cache ID对应的缓存内容是否可用
 if ($content = $cache->start($cache_id))
 {
  //缓存已存在,直接输出,并结束脚本
  echo $content;
  exit();
 }

 // 缓存中不存在该内容,生成新内容并写入缓存
 echo "这是内容。<P>";
 echo "当前时间是" . date('M-d-Y H:i:s A', time()) . "<BR>";

 // 把内容写入缓存
 echo $cache->end();
?>

  分别刷新这两个文件,你会发现pear_content_cache1.php中的“当前时间是”这一行中的时间是随着刷新而变化的,而pear_content_cache2.php中的这一行则不变。这是由于pear_content_cache2.php使用了缓存,将用户请求的内容存入静态文件中。当用户再次请求时,它直接从文件中输出,而不需要用程序动态生成内容。

  对于pear_content_cache2.php,如果用户想要读取最新的信息,而不是缓存中成旧的信息。那么可以用http://…/pear_content_cache2.php?nocache=1 来访问,这将禁用缓存功能。刷新一下看看,你将发现时间会随之变化。

  总结一下PEAR内容缓存类的使用:

  1.包含PEAR包 要注意设对路径。
 
  2.包含Output.php中的cache类

require_once 'Cache/Output.php';

  3.设置缓存目录

$cacheDir = './pear_cache';

  确认这个目录是可写的。Cache数据将会写入这个目录的子目录中。

  4.建立一个输出缓存对象

$cache = new Cache_Output('file',array('cache_dir' => $cacheDir));

  第一个参数表示我们使用基于“文件”方式的缓存,第二个参数是一个与缓存目录相关联的数组。

  5.产生一个唯一的cache ID

$cache_id = $cache->generateID(array('url' => $_REQUEST,'post' =>$_POST,'cookies' => $HTTP_COOKIE_VARS));

  这里$cache对象的generateID()方法通过提供一个信息数组(URL, HTTP POST data, 和 HTTP cookie)来独一无二地标识这个请求,与其它请求区分开来。

  6.增加一个逻辑判断语句看是否对应于cacheID的缓存数据是否已经存在,如果存在,获取数据并结束脚本。

if ($content = $cache->start($cache_id))
{
 echo $content;
 exit();
}

  7. 将产生内容的代码放在以上逻辑语句之后,并结束使用cache对象。