Thinkphp 框架扩展之驱动扩展实例分析
本文实例讲述了Thinkphp框架扩展之驱动扩展。分享给大家供大家参考,具体如下:
每个类库都可以设计自己的驱动,因此3.2版本的驱动目录没有独立出来,而是放到各个类库的命名空间下面,例如:Think\Log类的驱动放到Think\Log\Driver命名空间下面,Think\Db类的驱动放到了Think\Db\Driver命名空间下面。
当然,这只是建议的位置,你完全可以根据项目的需要,把自己的驱动独立存放,例如:Home\Driver\Cache\Sae.class.php则是一种把Cache驱动独立存放的方式(内置的核心类库都支持给驱动指定单独的命名空间)。
缓存驱动
缓存驱动默认位于Think\Cache\Driver命名空间下面,目前已经提供了包括APC、Db、Memcache、Shmop、Sqlite、Redis、Eaccelerator和Xcache缓存方式的驱动扩展,缓存驱动必须继承Think\Cache类,并实现下面的驱动接口:
| 方法说明 | 接口方法 |
|---|---|
| 架构方法 | __construct($options='') |
| 读取缓存 | get($name) |
| 写入缓存 | set($name,$value,$expire=null) |
| 删除缓存 | rm($name) |
| 清空缓存 | clear() |
下面是一个典型的缓存驱动类定义:
namespaceThink\Cache\Driver;
useThink\Cache;
/**
*Test缓存驱动
*/
classTestextendsCache{
/**
*读取缓存
*@accesspublic
*@paramstring$name缓存变量名
*@returnmixed
*/
publicfunctionget($name){
//获取名称为name的缓存
}
/**
*写入缓存
*@accesspublic
*@paramstring$name缓存变量名
*@parammixed$value存储数据
*@paraminteger$expire有效时间(秒)
*@returnboolean
*/
publicfunctionset($name,$value,$expire=null){
//设置缓存
}
/**
*删除缓存
*@accesspublic
*@paramstring$name缓存变量名
*@returnboolean
*/
publicfunctionrm($name){
//删除名称为name的缓存
}
/**
*清除缓存
*@accesspublic
*@returnboolean
*/
publicfunctionclear(){
//清空缓存
}
}
注意:缓存驱动的有效期参数约定,如果设置为0则表示永久缓存。
如果要让缓存驱动支持缓存队列功能,需要在缓存接口的set操作方法设置成功后添加如下代码:
if($this->options['length']>0){
//记录缓存队列
$this->queue($name);
}
要配置当前默认的缓存驱动类型可以使用CACHE_TYPE参数,例如:
'CACHE_TYPE'=>'test'
更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《ZendFrameWork框架入门教程》及《PHP模板技术总结》。
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。