Thinkphp 框架扩展之驱动扩展实例分析
程序员文章站
2022-06-17 14:35:17
本文实例讲述了thinkphp 框架扩展之驱动扩展。分享给大家供大家参考,具体如下:每个类库都可以设计自己的驱动,因此3.2版本的驱动目录没有独立出来,而是放到各个类库的命名空间下面,例如:think...
本文实例讲述了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() |
下面是一个典型的缓存驱动类定义:
namespace think\cache\driver; use think\cache; /** * 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() { // 清空缓存 } }
注意:缓存驱动的有效期参数约定,如果设置为0 则表示永久缓存。
如果要让缓存驱动支持缓存队列功能,需要在缓存接口的set操作方法设置成功后添加如下代码:
if($this->options['length']>0) { // 记录缓存队列 $this->queue($name); }
要配置当前默认的缓存驱动类型可以使用cache_type参数,例如:
'cache_type'=>'test'
上一篇: 车联网V2X深度应用,聚焦CIDI智能网联交叉路口技术
下一篇: 软件质量