首頁  >  文章  >  後端開發  >  關於session 加入redis的實現

關於session 加入redis的實現

不言
不言原創
2018-07-03 15:39:381433瀏覽

本篇文章主要介紹了session 加入redis 的實例,對session 進行了詳細介紹,並提供了程式碼實例,需要的朋友可以參考下

Session資訊入redis

#Session簡介

session,中文常翻譯為會話,其本來的意思是指有始有終的一系列動作/訊息,例如打電話時從拿起電話撥號到掛斷電話這中間的一系列過程可以稱為一個session。有時候我們可以看到這樣的話“在 一個瀏覽器會話期間,...”,這裡的會話一詞用的就是其本義,是指從一個瀏覽器窗口打開到關閉這個期間①。最混亂的是「使用者(客戶端)在一次會話期間」這樣一句話,它可能指使用者的一系列動作(般情況下是同某個具體目的相關的一系列動作,例如從登入到選購商品到結帳登出這樣一個網上購物的過程,有時候也被稱為一個transaction),然而有時候也可能僅僅是指一次連接,也有可能是指含義①,其中的差別只能靠上下文來推斷②。

在本文中,使用中文“瀏覽器會話期間”來表達含義①,使用“session機制”來表達含義④,使用“session”表達含義⑤,使用具體的“HttpSession”來表達意義⑥

為什麼要把SESSION保存在快取

就php來說,語言本身支援的session是以檔案的方式儲存到磁碟檔案中,儲存在指定的資料夾中,已儲存的路徑可以在設定檔中設定或在程式中使用函數session_save_path()進行設置,但是這麼做有弊端,
第一就是要儲存到文件系統中,效率低,只要有用到session就會從好多個檔案中找出指定的sessionid,效率很低。
第二就是當用到多台伺服器的時候可能會出現,session遺失問題(其實是儲存在其他伺服器上)了。
當然了,保存在快取中可以解決上面的問題,如果使用php本身的session函數,可以使用 session_set_save_handler()函數很方便的對session的處理過程進行重新控制。如果不用php的session系列函數, 可以自己寫個類似的session函數,也是可以的,我現在做的這個專案就是這樣,會根據使用者的mid、登入時間進行求hash作為sessionId,每次請求的時候都必須加上sessionId才算合法(第一次登入的時候是不需要的,這個時候會建立sessionId,回傳給客戶端),這麼做也很方便、簡潔有效率的。當然了,我這篇文章主要說的是在php自身的SESSION中」做做手腳」。

SESSION保存在快取中

#php將快取保存到redis中,可以使用設定文件,對session的處理和保存做修改,當然了,在程式中使用ini_set()函數去修改也可以,這個很方便測試,我在這裡就用這種方式,當然了,要是生產環境還是建議使用設定檔。

如果想簡單操作session入redis操作可以將一下程式碼執行一下

<?php 
 
ini_set("session.save_handler", "redis"); 
 
ini_set("session.save_path", "tcp://localhost:6379"); 
 
session_start(); 
 
header("Content-type:text/html;charset=utf-8"); 
 
if(isset($_SESSION[&#39;view&#39;])){ 
 
  $_SESSION[&#39;view&#39;] = $_SESSION[&#39;view&#39;] + 1; 
 
}else{ 
 
  $_SESSION[&#39;view&#39;] = 1; 
 
} 
 
echo "【view】{$_SESSION[&#39;view&#39;]}"; 
 
//这里设置session.save_handler方式为redis,session.save_path为redis的地址和端口,设置之后刷新,再回头查看redis,会发现redis中的生成了sessionId,sessionId和浏览器请求的是一样的, 
 
  
 
//也可以使用 
 
Session_set_save_handler(‘open&#39;,&#39;close&#39;,&#39; read&#39;,&#39; write&#39;,&#39; destory&#39;,&#39; gc&#39;); 
 
//用法如下自定义一个Redis_session类 
 
<?php 
 
class RedisSession{ 
 
  private $_redis = array( 
 
    &#39;handler&#39; => null, //数据库连接句柄 
 
    &#39;host&#39; => null,  //redis端口号 
 
    &#39;port&#39; => null, 
 
  ); 
 
  public function __construct($array = array()){ 
 
    isset($array[&#39;host&#39;])?$array[&#39;host&#39;]:"false"; 
 
    isset($array[&#39;port&#39;])?$array[&#39;host&#39;]:"false"; 
 
    $this->_redis = array_merge($this->_redis, $array); 
 
  } 
 
  public function begin(){ 
 
    //设置session处理函数 
 
    session_set_save_handler( 
 
      array($this, &#39;open&#39;), 
 
      array($this, &#39;close&#39;), 
 
      array($this, &#39;read&#39;), 
 
      array($this, &#39;write&#39;), 
 
      array($this, &#39;destory&#39;), 
 
      array($this, &#39;gc&#39;) 
 
    ); 
 
  } 
 
  public function open(){ 
 
    $redis = new Redis(); 
 
    $redis->connect($this->_redis[&#39;host&#39;], $this->_redis[&#39;port&#39;]); 
 
    if(!$redis){ 
 
      return false; 
 
    } 
 
  
 
    $this->_redis[&#39;handler&#39;] = $redis; 
 
    $this->gc(null); 
 
    return true; 
 
  } 
 
  //关 
 
  public function close(){ 
 
    return $this->_redis[&#39;handler&#39;]->close(); 
 
  } 
 
  //读 
 
  public function read($session_id){ 
 
    return $this->_redis[&#39;handler&#39;]->get($session_id); 
 
  } 
 
  //写 
 
  public function write($sessionId, $sessionData){ 
 
    return $this->_redis[&#39;handler&#39;]->set($sessionId, $sessionData); 
 
  } 
 
  public function destory($sessionId){ 
 
    return $this->_redis[&#39;handler&#39;]->delete($sessionId) >= 1 ? true : false; 
 
  } 
 
  public function gc(){ 
 
    //获取所有sessionid,让过期的释放掉 
 
    $this->_redis[&#39;handler&#39;]->keys("*"); 
 
    return true; 
 
  } 
 
} 
 
$ses = new RedisSession(array(&#39;host&#39;=>&#39;127.0.0.1&#39;,&#39;port&#39;=>&#39;6379&#39;)); 
 
$ses->begin(); 
 
session_start(); 
 
$_SESSION[&#39;name&#39;]=&#39;zhangsan&#39;; 
 
echo $_SESSION[&#39;name&#39;];

這樣就可以實作session資料如redis程式碼執行過程中必須安裝redis才可以。

以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網!

相關推薦:

關於php htmlentities()函數的定義和用法

關於PHP7.1使用openssl替換mcrypt的介紹

以上是關於session 加入redis的實現的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn