将Session放入Redis

默认情况下,我们的PHP是以文件的形式保存Session数据,所以,每次读写会话信息,就需要去访问硬盘。

为了解决会话信息夸域名问题,即为了实现同一时刻只能一个地方登录,同时也解决读写会话信息必须访问磁盘问题,我想到了,将Session保存到Redis中。

下面贴代码:


sessionRedis::setSessionHandler();
class sessionRedis{
public static $redis;

public static function sessionOpen($savePath,$sessionName){
self::$redis = new Redis();
self::$redis->connect(RedisHost,RedisPort);
self::$redis->select(3);

return true;
}

public static function sessionClose(){
return true;
}

public static function sessionRead($sessionId){
$data = self::$redis->get($sessionId);

return $data;
}

public static function sessionWrite($sessionId,$data){
$userId = self::getUserId();
if(!empty($userId)){
$ukey = 'uid' . $userId;
if(self::$redis->hExists('uid',$ukey)){
$ssid = self::$redis->hGet('uid',$ukey);
self::sessionDestroy($ssid);
}
self::$redis->hSet('uid',$ukey,$sessionId);
}
//$cache_expire = session_get_cookie_params();
$cache_expire = ini_get("session.gc_maxlifetime");
self::$redis->setex($sessionId,$cache_expire,$data);

return true;
}

public static function sessionDestroy($sessionId){
self::$redis->del($sessionId);

return true;
}

public static function sessionGC($maxlifetime){
//self::$redis->persist();

return true;
}

public static function setSessionHandler(){
session_set_save_handler(
array(__CLASS__,"sessionOpen"),
array(__CLASS__,"sessionClose"),
array(__CLASS__,"sessionRead"),
array(__CLASS__,"sessionWrite"),
array(__CLASS__,"sessionDestroy"),
array(__CLASS__,"sessionGC")
);

return true;
}

/*
这里获取登录的用户ID
*/
public static function getUserId(){
return isset($_SESSION['n_userId']) ? $_SESSION['n_userId'] : 0;
}
}


主要目的是用了实现一个帐号只能在一个地方登录,如果相同的帐号在别处再次登录,前一次登录的会话数据将被清掉!

代码简洁高效,是我的风格,哈哈!

目前PHP已经原生支持将session存入Redis里,所以,如果只是简单的把session信息保存至Redis里,只需要在php配置文件里设置一下

session.save_handler = redis
session.save_path = "tcp://host1:6379?weight=1, tcp://host2:6379?weight=2&timeout=2.5, tcp://host3:6379?weight=2"


这样就ok 了!

原文地址:https://www.cnblogs.com/yjken/p/3917904.html