一個基於redis的處理session的方法,如下。
<?phpclass Session_custom { private $redis; // redis執行個體 private $prefix = 'sess_'; // session_id首碼 // 會話開始時,會執行該方法,串連redis伺服器 public function open($path, $name) { $this->redis = new Redis(); return $this->redis->connect("127.0.0.1",6379); } // 會話結束時,調用該方法,關閉redis串連 public function close() { $this->redis->close(); return true; } // 會話儲存資料時調用該方法,在指令碼執行完或session_write_close方法調用之後調用 public function write($session_id, $data) { return $this->redis->hMSet($this->prefix.$session_id, array('expires' => time(), 'data' => $data)); } // 在自動開始會話或者通過調用 session_start() 函數手動開始會話之後,PHP 內部調用 read 回呼函數來擷取會話資料。 public function read($session_id) { if($this->redis->exists($this->prefix.$session_id)) { return $this->redis->hGet($this->prefix.$session_id, 'data'); } return ''; } // 清除會話中的資料,當調用session_destroy()函數,或者調用 session_regenerate_id()函數並且設定 destroy 參數為 TRUE 時,會調用此回呼函數。 public function destroy($session_id) { if($this->redis->exists($this->prefix.$session_id)) { return $this->redis->del($this->prefix.$session_id) > 0 ? true : false; } return true; } // 記憶體回收函數,調用周期由 session.gc_probability 和 session.gc_divisor 參數控制 public function gc($maxlifetime) { $allKeys = $this->redis->keys("{$this->prefix}*"); foreach($allKeys as $key) { if($this->redis->exists($key) && $this->redis->hGet($key, 'expires') + $maxlifetime < time()) { $this->redis->del($key); } } return true; }}// 調用自訂的session處理方法$handler = new Session_custom();session_set_save_handler( array($handler, 'open'), array($handler, 'close'), array($handler, 'read'), array($handler, 'write'), array($handler, 'destroy'), array($handler, 'gc'));// 下面這行代碼可以防止使用對象作為會話儲存管理器時可能引發的非預期行為,表示當指令碼執行之後或調用exit()之後,儲存當前會話資料並關閉當前會話register_shutdown_function('session_write_close');session_start();// 可以使用session了
補充:
php.ini檔案中的session.gc_probability與session.gc_divisor兩個配置選項共同決定gc函數調用的時機。預設值分為為1和1000,表示每個請求只有1/1000的機會調用gc函數。
以上就是本文的全部內容,希望對大家的學習有所協助。