php默认使用文件存储session,如果并发量大,效率非常低。而redis对高并发的支持非常好,所以,可以使用redis替代文件存储session。
这里,介绍下php的session_set_save_handler 函数的作用和使用方法。该函数定义用户级session保存函数(如打开、关闭、写入等)。原型如下:
bool session_set_save_hanler(callback open,callback close,callback read,callback write,callback destory,callback gc)
在使用该函数前,先把php.ini配置文件的session.save_handler选项设置为user,否则session_set_save_handle 不会生效。
下面是使用redis存储session的一个实例。
编写一个session管理类sessionManager ,代码如下:
class SessionManager {
private $reids;
private $sessionSavePath;
private $sessionName;
private $sessionExpireTime=300;
public function __construct() {
$this->reids=new Redis();
$this->reids->connect('127.0.0.1',6379);
$retval=session_set_save_handler(
array($this,"open"),
array($this,"close"),
array($this,"read"),
array($this,"write"),
array($this,"destroy"),
array($this,"gc")
);
}
public function open($path,$name) {
return true;
}
public function close() {
return true;
}
public function read($id) {
$vale=$this->reids->get($id);
if($vale) {
return $vale;
}else {
return '';
}
}
public function write($id,$data) {
if($this->reids->set($id,$data)) {
$this->reids->expire($id,$this->sessionExpireTime);
return true;
}
return false;
}
public function destroy($id) {
if($this->reids->delete($id)) {
return true;
}
return false;
}
public function gc($maxlifetime) {
return true;
}
public function __destruct() {
session_write_close();
}
}
?>
SessionManager构造函数主要用来连接Redis服务器,使用session_set_save_handler函数设置session回调函数,并调用session_start函数开启session功能。因为本例中open、close和gc回调函数的作用不是很大,所以直接返回true。
在write回调函数中,以session id 作为key,把session的数据作为value存储到redis服务器,设置session的过期时间为300秒。在read回调函数重,以session ID 作为key从redis服务器中读取数据,并返回此数据。而在destroy回调函数重,则以session ID 作为key 从redis服务器中删除对应的session数据。
使用时,只需包含SessionManager类,然后实例化一个SessionManager对象。下面建立个session_set.php文件。输入代码
include("SessionManager.php");
new SessionManager(); //开启session管理
$_SESSION['username']='hezikuang';//创建session变量
?>
然后再创建一个session_get.php文件,输入如下代码:
include("SessionManager.php");
new SessionManager(); //开启session管理
echo $_SESSION['username'];
?>
可以访问session_get.php,看看是否成功。