php实现数据缓存文件下载,php实现文件数据缓存实现代码_PHP教程

php实现文件数据缓存实现代码缓存技术是每次访问页面的时候,都会先检测相应的缓存是否存在,如果不存在,就连接数据库,得到数据,完成模板变量的赋值,显示页面,同时生成缓存文件,这样下次访问的时候缓存文件就发挥作用了

php教程实现文件数据缓存实现代码

缓存技术是每次访问页面的时候,都会先检测相应的缓存是否存在,如果不存在,就连接数据库教程,得到数据,完成模板变量的赋值,显示页面,同时生成缓存文件,这样下次访问的时候缓存文件就发挥作用了,而不会再执行if块的数据查询语句了。当然,在实际使用中会有很多东西要考虑,比如,有效期的设置,缓存组的设置等等* @license new bsd license

* @version $id: cache/apc.php 版本号 2010-04-18 23:02 cmpan $

*/

class cache_apc extends cache_abstract {

protected $_prefix = 'cache.mjie.net';

public function __construct() {

if (!function_exists('apc_cache_info')) {

throw new cacheexception('apc extension didn't installed');

}

}

/**

* 保存缓存变量

*

* @param string $key

* @param mixed $value

* @return bool

*/

public function store($key, $value) {

return apc_store($this->_storagekey($key), $value);

}

/**

* 读取缓存

*

* @param string $key

* @return mixed

*/

public function fetch($key) {

return apc_fetch($this->_storagekey($key));

}

/**

* 清除缓存

*

* @return cache_apc

*/

public function clear() {

apc_clear_cache();

return $this;

}

/**

* 删除缓存单元

*

* @return cache_apc

*/

public function delete($key) {

apc_delete($this->_storagekey($key));

return $this;

}

/**

* 缓存单元是否被锁定

*

* @param string $key

* @return bool

*/

public function islocked($key) {

if ((apc_fetch($this->_storagekey($key) . '.lock')) === false) {

return false;

}

return true;

}

/**

* 锁定缓存单元

*

* @param string $key

* @return cache_apc

*/

public function lock($key) {

apc_store($this->_storagekey($key) . '.lock', '', 5);

return $this;

}

/**

* 缓存单元解锁

*

* @param string $key

* @return cache_apc

*/

public function unlock($key) {

apc_delete($this->_storagekey($key) . '.lock');

return $this;

}

/**

* 完整缓存名

*

* @param string $key

* @return string

*/

private function _storagekey($key) {

return $this->_prefix . '_' . $key;

}

}

/**

* 文件缓存实现

*

*

* @category mjie

* @package cache

* @author 流水孟春

* @copyright copyright (c) 2008- * @license new bsd license

* @version $id: cache/file.php 版本号 2010-04-18 16:46 cmpan $

*/

class cache_file extends cache_abstract {

public $usesubdir = false;

protected $_cachesdir = 'cache';

public function __construct() {

if (defined('data_dir')) {

$this->_setcachedir(data_dir . '/cache');

}

}

/**

* 获取缓存文件

*

* @param string $key

* @return string

*/

protected function _getcachefile($key) {

$subdir = $this->usesubdir ? substr($key, 0, 2) . '/' : '';

return $this->_cachesdir . '/' . $subdir . $key . '.php';

}

/**

* 读取缓存变量

* 为防止信息泄露,缓存文件格式为php文件,并以""开头

*

* @param string $key 缓存下标

* @return mixed

*/

public function fetch($key) {

$cachefile = self::_getcachefile($key);

if (file_exists($cachefile) && is_readable($cachefile)) {

// include 方式

//return include $cachefile;

// 系列化方式

return unserialize(@file_get_contents($cachefile, false, null, 13));

}

return false;

}

/**

* 缓存变量

* 为防止信息泄露,缓存文件格式为php文件,并以""开头

*

* @param string $key 缓存变量下标

* @param string $value 缓存变量的值

* @return bool

*/

public function store($key, $value) {

$cachefile = self::_getcachefile($key);

$cachedir = dirname($cachefile);

if(!is_dir($cachedir)) {

if(!@mkdir($cachedir, 0755, true)) {

throw new cacheexception("could not make cache directory");

}

}

// 用include方式

//return @file_put_contents($cachefile, '' . serialize($value));

}

/**

* 删除缓存变量

*

* @param string $key 缓存下标

* @return cache_file

*/

public function delete($key) {

if(emptyempty($key)) {

throw new cacheexception("missing argument 1 for cache_file::delete()");

}

$cachefile = self::_getcachefile($key);

if(!@unlink($cachefile)) {

throw new cacheexception("cache file could not be deleted");

}

return $this;

}

/**

* 缓存单元是否已经锁定

*

* @param string $key

* @return bool

*/

public function islocked($key) {

$cachefile = self::_getcachefile($key);

clearstatcache();

return file_exists($cachefile . '.lock');

}

/**

* 锁定

*

* @param string $key

* @return cache_file

*/

public function lock($key) {

$cachefile = self::_getcachefile($key);

$cachedir = dirname($cachefile);

if(!is_dir($cachedir)) {

if(!@mkdir($cachedir, 0755, true)) {

if(!is_dir($cachedir)) {

throw new cacheexception("could not make cache directory");

}

}

}

// 设定缓存锁文件的访问和修改时间

@touch($cachefile . '.lock');

return $this;

}

/**

* 解锁

*

* @param string $key

* @return cache_file

*/

public function unlock($key) {

$cachefile = self::_getcachefile($key);

@unlink($cachefile . '.lock');

return

下面来看一款关于smarty缓存的文件实例代码

再来看看smarty提供的页面缓存功能:

1

2require('smarty.class.php');

3$smarty = new smarty;

4$smarty->caching = true;

5if(!$smarty->is_cached('index.tpl')) {

6 // no cache available, do variable assignments here.

7 $contents = get_database_contents();

8 $smarty->assign($contents);

9}

10$smarty->display('index.tpl');

11?>

php缓存技术工作时,当程序查询数据的时候,会把相应的结果序列化后保存到文件中,以后同样的查询语句就可以不用直接查询数据库,而是从缓存文件中获得。这一改进使得程序运行速度得以太幅度提升.

http://www.bkjia.com/PHPjc/444824.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/444824.htmlTechArticlephp实现文件数据缓存实现代码缓存技术是每次访问页面的时候,都会先检测相应的缓存是否存在,如果不存在,就连接数据库,得到数据,...

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值