主頁(yè) > 知識(shí)庫(kù) > 如何使用Redis保存用戶會(huì)話Session詳解

如何使用Redis保存用戶會(huì)話Session詳解

熱門標(biāo)簽:廊坊外呼系統(tǒng)在哪買 一個(gè)地圖標(biāo)注多少錢 400電話辦理的口碑 南京手機(jī)外呼系統(tǒng)廠家 地圖標(biāo)注工廠入駐 b2b外呼系統(tǒng) 臺(tái)灣電銷 高碑店市地圖標(biāo)注app 四川穩(wěn)定外呼系統(tǒng)軟件

前言

PHP內(nèi)置的繪畫存儲(chǔ)機(jī)制是把全部的會(huì)話數(shù)據(jù)保存在服務(wù)器上的文本文件里面,這些文件通常都是保存在服務(wù)器上的臨時(shí)目錄里。如果并發(fā)量大,讀寫效率非常低。而Redis對(duì)高并發(fā)的支持非常好,所以,可以使用redis替代文件存儲(chǔ)session。

下載源碼

session_set_save_handler函數(shù)

PHP的session_set_save_handler函數(shù)用來(lái)定義用戶級(jí)session保存函數(shù)(如打開、關(guān)閉、寫入等)。原型如下:

bool session_set_save_hanler(callback open,callback close,callback read,callback write,callback destory,callback gc)

參數(shù) 描述
open 當(dāng)session打開時(shí)調(diào)用此函數(shù)。接收兩個(gè)參數(shù),第一個(gè)參數(shù)是保持session的路徑,第二個(gè)參數(shù)是session的名字。此回調(diào)函數(shù)操作成功返回 TRUE,反之返回 FALSE。
close 當(dāng)session操作完成時(shí)調(diào)用此函數(shù)。不接收參數(shù)。此回調(diào)函數(shù)操作成功返回 TRUE,反之返回 FALSE。
read 以session ID作為參數(shù)。通過(guò)session ID從數(shù)據(jù)存儲(chǔ)方中取得數(shù)據(jù),并返回此數(shù)據(jù)。如果數(shù)據(jù)為空,可以返回一個(gè)空字符串。此函數(shù)在調(diào)用session_start 前被觸發(fā)
write 當(dāng)數(shù)據(jù)存儲(chǔ)時(shí)調(diào)用。有兩個(gè)參數(shù),一個(gè)是session ID,另外一個(gè)是session的數(shù)據(jù)
destroy 當(dāng)調(diào)用session_destroy 函數(shù)時(shí)觸發(fā)destroy函數(shù)。只有一個(gè)參數(shù) session ID,此回調(diào)函數(shù)操作成功返回 TRUE,反之返回 FALSE。
gc 當(dāng)php執(zhí)行session垃圾回收機(jī)制時(shí)觸發(fā),此回調(diào)函數(shù)操作成功返回 TRUE,反之返回 FALSE。

Session管理類

找到PHP的配置文件php.ini,修改為下面內(nèi)容,保存并重啟php-fpm服務(wù)。

session.save_handler = redis

我們編寫一個(gè)用來(lái)管理session的類:

?php 
class SessionManager{

 private $redis;
 private $sessionSavePath;
 private $sessionName;
 private $sessionExpireTime = 60;//redis,session的過(guò)期時(shí)間為30s

 public function __construct(){
 $this->redis = new Redis();//創(chuàng)建phpredis實(shí)例
 $this->redis->connect('127.0.0.1', 6379);//連接redis
 //$this->redis->auth("123456x");//授權(quán)
 $retval = session_set_save_handler(
 array($this,"open"),
 array($this,"close"),
 array($this,"read"),
 array($this,"write"),
 array($this,"destroy"),
 array($this,"gc")
 );
 session_start();
 }

 public function open($path,$name){
 return true;
 }

 public function close(){
 return true;
 }

 public function read($id){
 $value = $this->redis->get($id);//獲取redis中的指定記錄
 if($value){
 return $value;
 }else{
 return '';
 }
 }

 public function write($id,$data){
 if($this->redis->set($id,$data)){//以session ID為鍵,存儲(chǔ)
 $this->redis->expire($id,$this->sessionExpireTime);//設(shè)置redis中數(shù)據(jù)的過(guò)期時(shí)間,即session的過(guò)期時(shí)間
 return true;
 }

 return false;
 }

 public function destroy($id){
 if($this->redis->delete($id)){//刪除redis中的指定記錄
 return true;
 }
 return false;
 }

 public function gc($maxlifetime){
 return true;
 }

 public function __destruct(){
 session_write_close();
 }
}

SessionManager構(gòu)造函數(shù)主要用來(lái)連接Redis服務(wù)器,使用session_set_save_handler函數(shù)設(shè)置session回調(diào)函數(shù),并調(diào)用session_start函數(shù)開啟session功能。因?yàn)楸纠衞pen、close和gc回調(diào)函數(shù)的作用不是很大,所以直接返回true。

在write回調(diào)函數(shù)中,以session ID 作為key,把session的數(shù)據(jù)作為value存儲(chǔ)到redis服務(wù)器,設(shè)置session的過(guò)期時(shí)間為30秒。在read 回調(diào)函中,以session ID 作為key從redis服務(wù)器中讀取數(shù)據(jù),并返回此數(shù)據(jù)。而在destroy回調(diào)函數(shù)重,則以session ID 作為key 從redis服務(wù)器中刪除對(duì)應(yīng)的session數(shù)據(jù)。

使用Session

先建立一個(gè)set.php文件,用來(lái)設(shè)置Session:

?php 
require_once 'SessionManager.php';
new SessionManager();
$_SESSION['username'] = 'helloweba';

然后建立get.php文件,用來(lái)獲取Session:

?php 
require_once 'SessionManager.php';
new SessionManager();
echo $_SESSION['username'];

很顯然,我們先包含session管理類,然后實(shí)例化后就可以使用PHP正常的session函數(shù)了。

測(cè)試時(shí),首先訪問(wèn)set.php,然后再訪問(wèn)get.php,輸出結(jié)果如下所示:

最后,我們到redis里查看結(jié)果:

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

您可能感興趣的文章:
  • Redis連接錯(cuò)誤的情況總結(jié)分析
  • PHP實(shí)現(xiàn)基于Redis的MessageQueue隊(duì)列封裝操作示例
  • MySQL和Redis實(shí)現(xiàn)二級(jí)緩存的方法詳解
  • 詳解Redis中Lua腳本的應(yīng)用和實(shí)踐
  • Redis主從復(fù)制詳解
  • gem install redis報(bào)錯(cuò)的解決方案
  • 使用Ruby腳本部署Redis Cluster集群步驟講解
  • Linux下redis的持久化、主從同步與哨兵詳解
  • Redis Cluster的圖文講解
  • 一篇文章讓你明白R(shí)edis主從同步

標(biāo)簽:河源 畢節(jié) 泰州 伊春 甘南 南寧 拉薩 定州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《如何使用Redis保存用戶會(huì)話Session詳解》,本文關(guān)鍵詞  如何,使用,Redis,保存,用戶,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《如何使用Redis保存用戶會(huì)話Session詳解》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于如何使用Redis保存用戶會(huì)話Session詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 企业400电话

    智能AI客服机器人
    15000

    在线订购

    合计11份范本:公司章程+合伙协议+出资协议+合作协议+股权转让协议+增资扩股协议+股权激励+股东会决议+董事会决议

    推薦文章