在使用php做開發的時候會經常用到session,你可能會遇到session不失效,關掉浏覽器 session還存在,重新打開浏覽器sessionid還和以前一樣等問題。。。
接下來吾愛編程陪大家來看下php的session機制:
session 回收機制:
PHP采用Garbage Collection process對過期session進行回收,然而並不是每次session建立時,都能夠喚起 ‘garbage collection’ process ,gc是按照一定概率啟動的。這主要是出於對服務器性能方面的考慮,每個session都觸發gc,浏覽量大的話,服務器吃不消,然而按照一定概率開啟 gc,當流覽量大的時候,session過期機制能夠正常運行,而且服務器效率得到節省。細節應該都是多年的經驗積累得出的。
三個與PHP session過期相關的參數(php.ini中):
session.gc_probability = 1 session.gc_divisor = 1000 session.gc_maxlifetime = 1440
gc啟動概率 = gc_probability / gc_divisor = 0.1%
session過期時間 gc_maxlifetime 單位:秒
當web服務正式提供時,session過期概率就需要根據web服務的浏覽量和服務器的性能來綜合考慮session過期概率。為每個session都 開啟gc,顯然是不明智的,感覺有點“碰運氣”的感覺,要是訪問量小命中幾率就小。我在本機測試過程中,幾乎都沒有被命中過,sessionid幾天都不 變,哪怕機器重啟。測試過程中,這個過期概率值要設置大一點命中幾率才高點。
通過修改php配置文件的過期概率值,可以“碰運氣”式的設置session過期,那有沒有更好的辦法呢?
下面寫的這個session類可以徹底解決session不過期以及sessionid不變的問題。
/** * 擴展Session類(簡單封裝) * * @author slimboy * */ class Session { /** * 初始化 */ static function _init(){ ini_set('session.auto_start', 0); //Session::start(); } /** * 啟動Session */ static function start() { session_start(); } /** * 設置Session * * @param $name Session名稱 * @param $value 值 * @param $time 超時時間(秒) */ public static function set($name,$value,$time){ if(empty($time)){ $time = 1800; //默認值 } $_SESSION[$name] = $value; $_SESSION[$name.'_Expires'] = time() + $time; } /** * 獲取Session值 * * @param $name Session名稱 */ public static function get($name){ //檢查Session是否已過期 if(isset($_SESSION[$name.'_Expires']) && $_SESSION[$name.'_E xpires']>time()){ return $_SESSION[$name]; }else{ Session::clear($name); return null; } } /** * 設置Session Domain * * @param $sessionDomain 域 * @return string */ static function setDomain($sessionDomain = null) { $return = ini_get('session.cookie_domain'); if(!empty($sessionDomain)) { ini_set('session.cookie_domain', $sessionDomain);//跨 域訪問Session } return $return; } /** * 清除某一Session值 * * @param $name Session名稱 */ static function clear($name){ unset($_SESSION[$name]); unset($_SESSION[$name.'_Expires']); } /** * 重置銷毀Session */ static function destroy(){ unset($_SESSION); session_destroy(); } /** * 獲取或設置Session id */ static function sessionid($id=null){ return session_id($id); } }
簡單調用:
//設置session Session::set('UserId', $userid, 3600); //讀取session $userId = Session::get('UserId');*