php实现网页缓存的工具类分享

本文给大家分享的是php实现网页缓存的工具类的代码及使用方法,非常的实用,有需要的小伙伴可以参考下。

php程序在抵抗大流量访问的时候动态网站往往都是难以招架,所以要引入缓存机制,一般情况下有两种类型缓存

一、文件缓存

二、数据查询结果缓存,使用内存来实现高速缓存

本例主要使用文件缓存。

主要原理使用缓存函数来存储网页显示结果,如果在规定时间里再次调用则可以加载缓存文件。

工具类代码:

  1. // 文件缓存类
  2. class Cache {
  3. /**
  4. * $dir : 缓存文件存放目录
  5. * $lifetime : 缓存文件有效期,单位为秒
  6. * $cacheid : 缓存文件路径,包含文件名
  7. * $ext : 缓存文件扩展名(可以不用),这里使用是为了查看文件方便
  8. */
  9. private $dir;
  10. private $lifetime;
  11. private $cacheid;
  12. private $ext;
  13. /**
  14. * 析构函数,检查缓存目录是否有效,默认赋值
  15. */
  16. function __construct($dir = '', $lifetime = 1800) {
  17. if ($this->dir_isvalid ( $dir )) {
  18. $this->dir = $dir;
  19. $this->lifetime = $lifetime;
  20. $this->ext = '.Php';
  21. $this->cacheid = $this->getcacheid ();
  22. }
  23. }
  24. /**
  25. * 检查缓存是否有效
  26. */
  27. private function isvalid() {
  28. if (! file_exists ( $this->cacheid ))
  29. return false;
  30. if (! (@$mtime = filemtime ( $this->cacheid )))
  31. return false;
  32. if (mktime () - $mtime > $this->lifetime)
  33. return false;
  34. return true;
  35. }
  36. /**
  37. * 写入缓存
  38. * $mode == 0 , 以浏览器缓存的方式取得页面内容
  39. * $mode == 1 , 以直接赋值(通过$content参数接收)的方式取得页面内容
  40. * $mode == 2 , 以本地读取(fopen ile_get_contents)的方式取得页面内容(似乎这种方式没什么必要)
  41. */
  42. public function write($mode = 0, $content = '') {
  43. switch ($mode) {
  44. case 0 :
  45. $content = ob_get_contents ();
  46. break;
  47. default :
  48. break;
  49. }
  50. ob_end_flush ();
  51. try {
  52. file_put_contents ( $this->cacheid, $content );
  53. } catch ( Exception $e ) {
  54. $this->error ( '写入缓存失败!请检查目录权限!' );
  55. }
  56. }
  57. /**
  58. * 加载缓存
  59. * exit() 载入缓存后终止原页面程序的执行,缓存无效则运行原页面程序生成缓存
  60. * ob_start() 开启浏览器缓存用于在页面结尾处取得页面内容
  61. */
  62. public function load() {
  63. if ($this->isvalid ()) {
  64. // 以下两种方式,哪种方式好?????
  65. require_once ($this->cacheid);
  66. echo "<!--缓存-->";
  67. // echo file_get_contents($this->cacheid);
  68. exit ();
  69. } else {
  70. ob_start ();
  71. }
  72. }
  73. /**
  74. * 清除缓存
  75. */
  76. public function clean() {
  77. try {
  78. unlink ( $this->cacheid );
  79. } catch ( Exception $e ) {
  80. $this->error ( '清除缓存文件失败!请检查目录权限!' );
  81. }
  82. }
  83. /**
  84. * 取得缓存文件路径
  85. */
  86. private function getcacheid() {
  87. return $this->dir . md5 ( $this->geturl () ) . $this->ext;
  88. }
  89. /**
  90. * 检查目录是否存在或是否可创建
  91. */
  92. private function dir_isvalid($dir) {
  93. if (is_dir ( $dir ))
  94. return true;
  95. try {
  96. mkdir ( $dir, 0777 );
  97. } catch ( Exception $e ) {
  98. $this->error ( '所设定缓存目录不存在并且创建失败!请检查目录权限!' );
  99. return false;
  100. }
  101. return true;
  102. }
  103. /**
  104. * 取得当前页面完整url
  105. */
  106. private function geturl() {
  107. $url = '';
  108. if (isset ( $_SERVER ['REQUEST_URI'] )) {
  109. $url = $_SERVER ['REQUEST_URI'];
  110. } else {
  111. $url = $_SERVER ['Php_SELF'];
  112. $url .= emptyempty ( $_SERVER ['QUERY_STRING'] ) ? '' : '?' . $_SERVER ['QUERY_STRING'];
  113. }
  114. return $url;
  115. }
  116. /**
  117. * 输出错误信息
  118. */
  119. private function error($str) {
  120. echo '<div >' . $str . '</div>';
  121. }
  122. }

使用方法:

使用方法如下:

一部分代码放在要被缓存逻辑代码前面:

  1. $cachedir = './Cache/'; // 设定缓存目录
  2. $cache = new Cache ( $cachedir, 33 ); // 省略参数即采用缺省设置, $cache = new Cache($cachedir);
  3. if (@$_GET ['cacheact'] != 'rewrite' || @$_GET ['clearCache'] == 'ok') // 此处为一技巧,通过xx.Php?cacheact=rewrite更新缓存,以此类推,还可以设定一些其它操作
  4. $cache->load (); // 装载缓存,缓存有效则不执行以下页面代码
  5. // 页面代码开始

一部分放在被缓存逻辑代码后面,页面代码结束:

$cache->write (); // 首次运行或缓存过期,生成缓存

以上所述就是本文的全部内容了,希望大家能够喜欢。