一个PHP页面缓存类 修改后可作Emlog缓存插件
最近,细细看了许多关于缓存的文章,有程序级的、非程序级的、内存缓存、文件缓存等等,感觉获益良多,于是为巩固知识,强化记忆,自己也多动动手去写写关于缓存面的程序。
这是自己写的一个PHP文件缓存类,此类仅是对整页页面缓存,原理是对php响应http请求后编译生成的html代码,全部以文件形式存在服务器上,在缓存有效期内,直接读取访问缓存,缓存失效时,那么就像平时访问php一样查询数据库获取数据,同时此类为页面产生缓存文件,以便下次访问,减少对数据等查询损耗。
当然,这个类只不过是入门级的写法,简单实现,此为在整页缓存,类似于生成HTML成静态,只是此类可缓存一段时间并自动重新生成。还有许多CMS等系统常用到文件缓存,例如把数据库的表存到文件,又或者把部分数据存到文件中,有以php文件形式、有以序列化后存储的形式,原理都差不多,需求不同罢了,都可以实现相同的缓存效果。
文件缓存只是其中一种,还有其实缓存方式,例如php缓冲器:eaccelerator, apc, phpa,xcache等,基于反向代理的Web缓存:Nginx,SQUID,mod_proxy,常见的内存缓存如Memcached等。
代码:
Copy to Clipboard引用的内容:[www.bkjia.com] class fancyCache{
private static $_instance = NULL;
protected $_options =array();
/**
* 初始化构造函数
* $cacheDir : 缓存文件目录
* $expire : 缓存文件有效期,单位为秒
* $file_ext : 缓存文件后缀
*/
public static function init($cacheDir='./cache',$expire=1800,$file_ext='.htm')
{
$instance = self::getInstance();
//判断缓存目录是否有效
if($instance->isValidCacheDir($cacheDir))
{
$instance->_options['cache_dir']=rtrim($cacheDir,'/') . '/';
$instance->_options['expire']=$expire;
$instance->_options['file_ext']=$file_ext;
$instance->_options['cache_file_url']=$instance->getCacheFileUrl();
if($_SERVER['REQUEST_METHOD']=='GET')
{
//缓存未过期则读取缓存文件
if($instance->isExpired()) {
$instance->readCache();
exit;
}
else
{
//自动缓存
ob_start(array($instance,"autoCache"));
}
}
else
{
//不是GET请求则删除缓存
if(file_exists($instance->_options['cache_file_url']))unlink($instance->_options['cache_file_url']);
}
}
}
/**
* 获取当前对象
*/
public static function getInstance()
{
if(self::$_instance==NULL)
{
self::$_instance=new self();
}
return self::$_instance;
}
/**
* 读取缓存
*/
protected function readCache()
{
$instance =self::getInstance();
$fp =fopen($instance->_options['cache_file_url'],'rb');
fpassthru($fp);
fclose($fp);
}
/**
* 自动写入缓存
*/
public function autoCache($contents)
{
$instance = self::getInstance();
if($fp=fopen($instance->_options['cache_file_url'],'wb'))
{
if (flock($fp, LOCK_EX))
{
ftruncate($fp,0);
fwrite($fp, $contents);
fclose($fp);
chmod($instance->_options['cache_file_url'],0777);
}
}
self::DelOldCache();
return $contents;
}
/**
* 删除所有过期缓存
*/
protected function DelOldCache()
{
$instance = self::getInstance();
chdir($instance->_options['cache_dir']);
foreach (glob("*/*".$instance->_options['file_ext']) as $file)
{
if(time()-filemtime($file)>$instance->_options['expire'])unlink($file);
}
}
/**
* 验证缓存是否有效
* return true 已过期
*/
protected function isExpired()
{
$instance = self::getInstance();
if(!file_exists($instance->_options['cache_file_url']))return false;
if(time()-filemtime($instance->_options['cache_file_url'])>$instance->_options['expire'])return false;
return true;
}
/**
* 验证缓存目录是否存在,不存在则创建
* return true 存在或创建成功
*/
protected function isValidCacheDir($cacheDir)
{
$instance = self::getInstance();
$cacheDir=rtrim($cacheDir,'/') . '/';
if(!file_exists($cacheDir)){
try
{
mkdir($cacheDir,0777);
chmod($cacheDir,0777);
}
catch(Exception $e)
{
echo 'Failed to create cache dir!';
return false;
}
}
//创建缓存文件子目录
$cacheFileDir=$cacheDir.substr(md5($instance->getPageUrl()),0,1);
if(!file_exists($cacheFileDir))
{
try
{
mkdir($cacheFileDir,0777);
chmod($cacheFileDir,0777);
}
catch(Exception $e)
{
echo 'Failed to create cache dir!';
return false;
}
}
return true;
}
/**
* 取得缓存文件路径
*/
protected function getCacheFileUrl()
{
$instance =self::getInstance();
$pageUrl =md5($instance->getPageUrl());
return $instance->_options['cache_dir'].substr($pageUrl,0,1).'/'.$pageUrl.$instance->_options['file_ext'];
}
/**
* 取得当前访问页面完整url
*/
protected function getPageUrl() {
$url = '';
if (isset($_SERVER['REQUEST_URI'])) {
$url = $_SERVER['REQUEST_URI'];
}
else {
$url = $_SERVER['PHP_SELF'];
$url .= empty($_SERVER['QUERY_STRING'])?'':'?'.$_SERVER['QUERY_STRING'];
}
return $url;
}
}
?>
本博使用Emlog程序,所以本人对类稍做了修改以作Emlog缓存插
1、在类中加上(注释不能删)
Copy to Clipboard引用的内容:[www.bkjia.com] /*Plugin Name: fancyCache-页面缓存
Version: beta 1.0
Plugin URL: http://meego123.net/
Description: 使用fancyCache可用页面自动缓存
Author: Jamin
Author Email: wenjingmin@gmail.com
Author URL: http://meego123.net/
*/
!defined('EMLOG_ROOT') && exit('access deined!');
addAction('index_header', fancyCache::init(EMLOG_ROOT."/content/fancyCache",60*60*24));
2、文件名存为fancycache.php,并建立同名文件夹,将fancycache.php放到fancycache文件夹中,并一同放到Emlog插件目录/content/plugins下
3、到Emlog后台“功能扩展” -- ”插件“,开启插件即可
本文来源:http://meego123.net/?post=127

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



PHP 8.4 membawa beberapa ciri baharu, peningkatan keselamatan dan peningkatan prestasi dengan jumlah penamatan dan penyingkiran ciri yang sihat. Panduan ini menerangkan cara memasang PHP 8.4 atau naik taraf kepada PHP 8.4 pada Ubuntu, Debian, atau terbitan mereka

Kod Visual Studio, juga dikenali sebagai Kod VS, ialah editor kod sumber percuma — atau persekitaran pembangunan bersepadu (IDE) — tersedia untuk semua sistem pengendalian utama. Dengan koleksi sambungan yang besar untuk banyak bahasa pengaturcaraan, Kod VS boleh menjadi c

Tutorial ini menunjukkan cara memproses dokumen XML dengan cekap menggunakan PHP. XML (bahasa markup extensible) adalah bahasa markup berasaskan teks yang serba boleh yang direka untuk pembacaan manusia dan parsing mesin. Ia biasanya digunakan untuk penyimpanan data

Jika anda seorang pembangun PHP yang berpengalaman, anda mungkin merasakan bahawa anda telah berada di sana dan telah melakukannya. Anda telah membangunkan sejumlah besar aplikasi, menyahpenyahpepijat berjuta-juta baris kod dan mengubah suai sekumpulan skrip untuk mencapai op

JWT adalah standard terbuka berdasarkan JSON, yang digunakan untuk menghantar maklumat secara selamat antara pihak, terutamanya untuk pengesahan identiti dan pertukaran maklumat. 1. JWT terdiri daripada tiga bahagian: header, muatan dan tandatangan. 2. Prinsip kerja JWT termasuk tiga langkah: menjana JWT, mengesahkan JWT dan muatan parsing. 3. Apabila menggunakan JWT untuk pengesahan di PHP, JWT boleh dijana dan disahkan, dan peranan pengguna dan maklumat kebenaran boleh dimasukkan dalam penggunaan lanjutan. 4. Kesilapan umum termasuk kegagalan pengesahan tandatangan, tamat tempoh, dan muatan besar. Kemahiran penyahpepijatan termasuk menggunakan alat debugging dan pembalakan. 5. Pengoptimuman prestasi dan amalan terbaik termasuk menggunakan algoritma tandatangan yang sesuai, menetapkan tempoh kesahihan dengan munasabah,

Rentetan adalah urutan aksara, termasuk huruf, nombor, dan simbol. Tutorial ini akan mempelajari cara mengira bilangan vokal dalam rentetan yang diberikan dalam PHP menggunakan kaedah yang berbeza. Vokal dalam bahasa Inggeris adalah a, e, i, o, u, dan mereka boleh menjadi huruf besar atau huruf kecil. Apa itu vokal? Vokal adalah watak abjad yang mewakili sebutan tertentu. Terdapat lima vokal dalam bahasa Inggeris, termasuk huruf besar dan huruf kecil: a, e, i, o, u Contoh 1 Input: String = "TutorialSpoint" Output: 6 menjelaskan Vokal dalam rentetan "TutorialSpoint" adalah u, o, i, a, o, i. Terdapat 6 yuan sebanyak 6

Mengikat statik (statik: :) Melaksanakan pengikatan statik lewat (LSB) dalam PHP, yang membolehkan kelas panggilan dirujuk dalam konteks statik dan bukannya menentukan kelas. 1) Proses parsing dilakukan pada masa runtime, 2) Cari kelas panggilan dalam hubungan warisan, 3) ia boleh membawa overhead prestasi.

Apakah kaedah sihir PHP? Kaedah sihir PHP termasuk: 1. \ _ \ _ Membina, digunakan untuk memulakan objek; 2. \ _ \ _ Destruct, digunakan untuk membersihkan sumber; 3. \ _ \ _ Call, mengendalikan panggilan kaedah yang tidak wujud; 4. \ _ \ _ Mendapatkan, melaksanakan akses atribut dinamik; 5. \ _ \ _ Set, melaksanakan tetapan atribut dinamik. Kaedah ini secara automatik dipanggil dalam situasi tertentu, meningkatkan fleksibiliti dan kecekapan kod.
