Thinkphp 框架扩展之驱动扩展实例分析 |
||||||||||||
|
本文标签:Thinkphp,驱动扩展 本文实例讲述了Thinkphp 框架扩展之驱动扩展 。分享给大家供大家参考,具体如下: 每个类库都可以设计自己的驱动,因此3.2版本的驱动目录没有独立出来,而是放到各个类库的命名空间下面,例如:ThinkLog类的驱动放到 ThinkLogDriver 命名空间下面,ThinkDb类的驱动放到了 ThinkDbDriver 命名空间下面 。
缓存驱动缓存驱动默认位于ThinkCacheDriver命名空间下面,目前已经提供了包括APC、Db、Memcache、Shmop、Sqlite、Redis、Eaccelerator和Xcache缓存方式的驱动扩展,缓存驱动必须继承ThinkCache类,并实现下面的驱动接口:
下面是一个典型的缓存驱动类定义:
namespace ThinkCacheDriver;
use ThinkCache;
/**
* Test缓存驱动
*/
class Test extends Cache {
/**
* 读取缓存
* @access public
* @param string $name 缓存变量名
* @return mixed
*/
public function get($name) {
// 获取名称为name的缓存
}
/**
* 写入缓存
* @access public
* @param string $name 缓存变量名
* @param mixed $value 存储数据
* @param integer $expire 有效时间(秒)
* @return boolean
*/
public function set($name, $value, $expire = null) {
// 设置缓存
}
/**
* 删除缓存
* @access public
* @param string $name 缓存变量名
* @return boolean
*/
public function rm($name) {
// 删除名称为name的缓存
}
/**
* 清除缓存
* @access public
* @return boolean
*/
public function clear() {
// 清空缓存
}
}
如果要让缓存驱动支持缓存队列功能,需要在缓存接口的set操作方法设置成功后添加如下代码:
if($this->options['length']>0) {
// 记录缓存队列
$this->queue($name);
}
要配置当前默认的缓存驱动类型可以使用CACHE_TYPE参数,例如: 'CACHE_TYPE'=>'test' 更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《Zend FrameWork框架入门教程》及《PHP模板技术总结》 。 希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助 。 |