Thinkphp 框架扩展之驱动扩展实例分析

网络编程 2021-07-04 23:05www.168986.cn编程入门
这篇文章主要介绍了Thinkphp 框架扩展之驱动扩展,结合实例形式分析了Thinkphp 框架驱动扩展相关原理、实现方法及操作注意事项,需要的朋友可以参考下

本文实例讲述了Thinkphp 框架扩展之驱动扩展。分享给大家供大家参考,具体如下

每个类库都可以设计自己的驱动,3.2版本的驱动目录没有独立出来,而是放到各个类库的命名空间狼蚁网站SEO优化,例如Think\Log类的驱动放到 Think\Log\Driver 命名空间狼蚁网站SEO优化,Think\Db类的驱动放到了 Think\Db\Driver 命名空间狼蚁网站SEO优化。

,这只是建议的位置,你完全可以根据项目的需要,把自己的驱动独立存放,例如 Home\Driver\Cache\Sae.class.php 则是一种把Cache驱动独立存放的方式(内置的核心类库都支持给驱动指定单独的命名空间)。

缓存驱动

缓存驱动默认位于Think\Cache\Driver命名空间狼蚁网站SEO优化,目前已经提供了包括APC、Db、Memcache、Shmop、Sqlite、Redis、Eaelerator和Xcache缓存方式的驱动扩展,缓存驱动必须继承Think\Cache类,并实现狼蚁网站SEO优化的驱动接口

方法说明 接口方法
架构方法 __construct($options='')
读取缓存 get($name)
写入缓存 set($name,$value,$expire=null)
删除缓存 rm($name)
清空缓存 clear()

狼蚁网站SEO优化是一个典型的缓存驱动类定义

namespace Think\Cache\Driver;
use Think\Cache;
/
  Test缓存驱动
 /
class Test extends Cache {
  /
    读取缓存
    @aess public
    @param string $name 缓存变量名
    @return mixed
   /
   public function get($name) {
    // 获取名称为name的缓存
   }
  /
    写入缓存
    @aess public
    @param string $name 缓存变量名
    @param mixed $value 存储数据
    @param integer $expire 有效时间(秒)
    @return boolean
   /
   public function set($name, $value, $expire = null) {
    // 设置缓存
   }
  /
    删除缓存
    @aess public
    @param string $name 缓存变量名
    @return boolean
   /
   public function rm($name) {
    // 删除名称为name的缓存
   }
 
  /
    清除缓存
    @aess public
    @return boolean
   /
  public function clear() {
    // 清空缓存
  }
}

注意缓存驱动的有效期参数约定,如果设置为0 则表示永久缓存。

如果要让缓存驱动支持缓存队列功能,需要在缓存接口的set操作方法设置成功后添加如下代码

if($this->options['length']>0) {
    // 记录缓存队列
    $this->queue($name);
 }

要配置当前默认的缓存驱动类型可以使用CACHE_TYPE参数,例如

'CACHE_TYPE'=>'test'

更多关于thinkPHP相关内容感兴趣的读者可查看本站专题《》、《》、《》、《》、《》、《》及《》。

希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。

Copyright © 2016-2025 www.168986.cn 狼蚁网络 版权所有 Power by