日常中我们都会使用到session来保存用户登录的信息,常用的session的保存方式有:文件保存(默认)、数据库保存、Redis保存、memcached等。本文主要记录一下在用ThinkPHP3.1.*处理session用Redis来保存session的用法。
1. 在项目中新增配置:
'SESSION_TYPE'=> 'Redis', //session保存类型
'SESSION_PREFIX'=> 'sess_', //session前缀
'REDIS_HOST'=> '127.0.0.1', //REDIS服务器地址
'REDIS_PORT'=> 6379, //REDIS连接端口号
'SESSION_EXPIRE'=> 3600, //SESSION过期时间
以ThinkPHP/Common/functions.php文件中找到定义session的方法,大约在559行左右读取session驱动的判断。如果我们定义了配置项SESSION_TYPE,则会new一个Redis对象并调用会话存储函数session_set_save_handler()。
2. 在Thinkphp3.1.*框架/ThinkPHP/Extend/Driver/Session/下新建SessionRedis.class.php
<?php
defined('THINK_PATH') or exit();
class SessionRedis {
//Redis连接对象
private $redis;
//Session过期时间
private $expire;
/**
* 打开方法
* @param type $path
* @param type $name
* @return type
*/
public function open($path, $name) {
$this->expire = C('SESSION_EXPIRE') ? C('SESSION_EXPIRE') : ini_get('session.gc_maxLifetime');
$this->redis = new Redis();
return $this->redis->connect(C('REDIS_HOST'), C('REDIS_PORT'));
}
/**
* 关闭
* @return type
*/
public function close() {
return $this->redis->close();
}
/**
* 读取
* @param string $id
* @return type
*/
public function read($id) {
$id = C('SESSION_PREFIX') . $id;
$data = $this->redis->get($id);
return $data ? $data : '';
}
/**
* 写入
* @param string $id
* @param type $data
* @return type
*/
public function write($id, $data) {
$id = C('SESSION_PREFIX') . $id;
return $this->redis->set($id, $data, $this->expire);
}
/**
* 销毁
* @param string $id
*/
public function destroy($id) {
$id = C('SESSION_PREFIX') . $id;
$this->redis->delete($id);
}
/**
* 垃圾回收
* @param type $maxLifeTime
* @return boolean
*/
public function gc($maxLifeTime) {
return true;
}
/**
* 打开Session
* @access public
*/
public function execute() {
session_set_save_handler(array(&$this,"open"),
array(&$this,"close"),
array(&$this,"read"),
array(&$this,"write"),
array(&$this,"destroy"),
array(&$this,"gc"));
}
}