php缓存功能的实现
时间:2023年10月05日
/来源:网络
/编辑:佚名
不同的网站所需要的缓存功能不一样,有的网站只需要缓存所请求的get信息,但是有的网站却需要缓存完整url的信息,这里记录一个常用到的缓存代码,目前已经写好了.
缓存代码
<?php
//缓存存放目录
define('CACHE_ROOT', dirname(__FILE__) . DIRECTORY_SEPARATOR . 'empirecms');
//缓存时间 单位秒
define('CACHE_TIME', 86400*7);
//缓存文件后缀
define('CACHE_FIX','.php');
date_default_timezone_set("Asia/Shanghai");
$CacheName=md5($_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI']) . CACHE_FIX; //缓存文件名
$CacheDir=CACHE_ROOT . DIRECTORY_SEPARATOR . substr($CacheName,0,1);//缓存文件存放目录
$CacheUrl=$CacheDir . DIRECTORY_SEPARATOR . $CacheName;//缓存文件的完整路径
//GET方式请求才缓存,POST之后一般都希望看到最新的结果
if($_SERVER['REQUEST_METHOD']!='POST'){
//如果缓存文件存在,并且没有过期,就把它读出来。
if(file_exists($CacheUrl) && time()-filemtime($CacheUrl)<CACHE_TIME){
echo gzuncompress(file_get_contents($CacheUrl));
exit;
}
//判断文件夹是否存在,不存在则创建
elseif(!file_exists($CacheDir)){
if(!file_exists(CACHE_ROOT)){
mkdir(CACHE_ROOT,0777);
chmod(CACHE_ROOT,0777);
}
mkdir($CacheDir,0777);
chmod($CacheDir,0777);
}
//回调函数,当程序结束时自动调用此函数
function AutoCache($contents){
global $CacheUrl;
$fp=fopen($CacheUrl,'wb');
$contents = "<!--站长qq:1810216796 缓存更新时间: ".(date("Y-m-d H:i:s", time()))."-->\r\n".$contents;
fwrite($fp,gzcompress($contents));
fclose($fp);
chmod($CacheUrl,0777);
//生成新缓存的同时,自动删除所有的老缓存,以节约空间,可忽略。
DelOldCache();
return $contents;
}
function DelOldCache(){
chdir(CACHE_ROOT);
foreach (glob("*/*".CACHE_FIX) as $file){
if(time()-filemtime($file)>CACHE_TIME) unlink($file);
}
}
ob_start('AutoCache');//回调函数 auto_cache
clearstatcache();//清除文件缓存
}else{
//不是GET的请求就删除缓存文件。
if(file_exists($CacheUrl)) unlink($CacheUrl);
}
?>
使用方法
使用的话,直接引用代码即可
代码重点
主要是php的回调函数不好理解,恶补一些基础后,勉强可以理解,其中ob_start这个函数我去查了一下手册,具体如下:
php缓存功能的实现
ob范例
用户自定义回调函数的例子
<?php
function callback ( $buffer )
{
// replace all the apples with oranges
return ( str_replace ( "apples" , "oranges" , $buffer ));
}
ob_start ( "callback" );
?>
<html>
<body>
<p>It's like comparing apples to oranges.</p>
</body>
</html>
<?php
ob_end_flush ();
?>
以上例程会输出:
<html>
<body>
<p>It's like comparing oranges to oranges.</p>
</body>
</html>
缓存代码
<?php
//缓存存放目录
define('CACHE_ROOT', dirname(__FILE__) . DIRECTORY_SEPARATOR . 'empirecms');
//缓存时间 单位秒
define('CACHE_TIME', 86400*7);
//缓存文件后缀
define('CACHE_FIX','.php');
date_default_timezone_set("Asia/Shanghai");
$CacheName=md5($_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI']) . CACHE_FIX; //缓存文件名
$CacheDir=CACHE_ROOT . DIRECTORY_SEPARATOR . substr($CacheName,0,1);//缓存文件存放目录
$CacheUrl=$CacheDir . DIRECTORY_SEPARATOR . $CacheName;//缓存文件的完整路径
//GET方式请求才缓存,POST之后一般都希望看到最新的结果
if($_SERVER['REQUEST_METHOD']!='POST'){
//如果缓存文件存在,并且没有过期,就把它读出来。
if(file_exists($CacheUrl) && time()-filemtime($CacheUrl)<CACHE_TIME){
echo gzuncompress(file_get_contents($CacheUrl));
exit;
}
//判断文件夹是否存在,不存在则创建
elseif(!file_exists($CacheDir)){
if(!file_exists(CACHE_ROOT)){
mkdir(CACHE_ROOT,0777);
chmod(CACHE_ROOT,0777);
}
mkdir($CacheDir,0777);
chmod($CacheDir,0777);
}
//回调函数,当程序结束时自动调用此函数
function AutoCache($contents){
global $CacheUrl;
$fp=fopen($CacheUrl,'wb');
$contents = "<!--站长qq:1810216796 缓存更新时间: ".(date("Y-m-d H:i:s", time()))."-->\r\n".$contents;
fwrite($fp,gzcompress($contents));
fclose($fp);
chmod($CacheUrl,0777);
//生成新缓存的同时,自动删除所有的老缓存,以节约空间,可忽略。
DelOldCache();
return $contents;
}
function DelOldCache(){
chdir(CACHE_ROOT);
foreach (glob("*/*".CACHE_FIX) as $file){
if(time()-filemtime($file)>CACHE_TIME) unlink($file);
}
}
ob_start('AutoCache');//回调函数 auto_cache
clearstatcache();//清除文件缓存
}else{
//不是GET的请求就删除缓存文件。
if(file_exists($CacheUrl)) unlink($CacheUrl);
}
?>
使用方法
使用的话,直接引用代码即可
代码重点
主要是php的回调函数不好理解,恶补一些基础后,勉强可以理解,其中ob_start这个函数我去查了一下手册,具体如下:
php缓存功能的实现
ob范例
用户自定义回调函数的例子
<?php
function callback ( $buffer )
{
// replace all the apples with oranges
return ( str_replace ( "apples" , "oranges" , $buffer ));
}
ob_start ( "callback" );
?>
<html>
<body>
<p>It's like comparing apples to oranges.</p>
</body>
</html>
<?php
ob_end_flush ();
?>
以上例程会输出:
<html>
<body>
<p>It's like comparing oranges to oranges.</p>
</body>
</html>
新闻资讯 更多
- 【建站知识】查询nginx日志状态码大于400的请求并打印整行04-03
- 【建站知识】Python中的logger和handler到底是个什么?04-03
- 【建站知识】python3拉勾网爬虫之(您操作太频繁,请稍后访问)04-03
- 【建站知识】xpath 获取meta里的keywords及description的方法04-03
- 【建站知识】python向上取整以50为界04-03
- 【建站知识】scrapy xpath遇见乱码解决04-03
- 【建站知识】scrapy爬取后中文乱码,解决word转为html 时cp1252编码问题04-03
- 【建站知识】scrapy采集—爬取中文乱码,gb2312转为utf-804-03