完全解決PHP Session不過時以及SessionId保持不變的問題

用過asp.net裏面的session再用過php裏面的session,你會以爲php 的session相比asp.net裏面的session是如此的不爽。在用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不變的問題。 php

<?php
 /**
  * 擴展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); 
    } 
 
}
?>
簡單調用:
<?php
    //設置session  
    Session::set('UserId', $userid, 3600); 
    //讀取session
    $userId = Session::get('UserId');
?>
相關文章
相關標籤/搜索