一個基於redis的處理session的方法,如下。
1 php 2class Session_custom { 3private$redis; // redis執行個體 4private$prefix = 'sess_'; // session_id首碼 5 6 // 會話開始時,會執行該方法,串連redis伺服器 7publicfunction open($path, $name) { 8$this->redis = new Redis(); 9return$this->redis->connect("127.0.0.1",6379);10 }1112// 會話結束時,調用該方法,關閉redis串連13publicfunction close() {14$this->redis->close();15returntrue;16 }1718// 會話儲存資料時調用該方法,在指令碼執行完或session_write_close方法調用之後調用19publicfunction write($session_id, $data) {20return$this->redis->hMSet($this->prefix.$session_id, array('expires' => time(), 'data' => $data));21 }2223// 在自動開始會話或者通過調用 session_start() 函數手動開始會話之後,PHP 內部調用 read 回呼函數來擷取會話資料。24publicfunction read($session_id) {25if($this->redis->exists($this->prefix.$session_id)) {26return$this->redis->hGet($this->prefix.$session_id, 'data');27 }28return '';29 }3031// 清除會話中的資料,當調用session_destroy()函數,或者調用 session_regenerate_id()函數並且設定 destroy 參數為 TRUE 時,會調用此回呼函數。32publicfunction destroy($session_id) {33if($this->redis->exists($this->prefix.$session_id)) {34return$this->redis->del($this->prefix.$session_id) > 0 ? true : false;35 }36returntrue;37 }3839// 記憶體回收函數,調用周期由 session.gc_probability 和 session.gc_divisor 參數控制40publicfunction gc($maxlifetime) {41$allKeys = $this->redis->keys("{$this->prefix}*");42foreach($allKeysas$key) {43if($this->redis->exists($key) && $this->redis->hGet($key, 'expires') + $maxlifetime < time()) {44$this->redis->del($key);45 }46 }47returntrue;48 }49}5051// 調用自訂的session處理方法52$handler = new Session_custom();53session_set_save_handler(54array($handler, 'open'),55array($handler, 'close'),56array($handler, 'read'),57array($handler, 'write'),58array($handler, 'destroy'),59array($handler, 'gc')60);6162// 下面這行代碼可以防止使用對象作為會話儲存管理器時可能引發的非預期行為,表示當指令碼執行之後或調用exit()之後,儲存當前會話資料並關閉當前會話63register_shutdown_function('session_write_close');6465session_start();6667// 可以使用session了
補充:
php.ini檔案中的session.gc_probability與session.gc_divisor兩個配置選項共同決定gc函數調用的時機。預設值分為為1和1000,表示每個請求只有1/1000的機會調用gc函數。
以上就介紹了基於redis的處理session的方法,包括了方面的內容,希望對PHP教程有興趣的朋友有所協助。