搜尋
首頁php教程php手册彻底解决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]
 
 
/**
 * 扩展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.'_Expires']>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::_init(); 


/**
 * 扩展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.'_Expires']>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::_init();

 

 

调用示例:


[php]
//设置session  
Session::set('UserId', $userid, 3600); 

//设置session
Session::set('UserId', $userid, 3600);
[php]
//读取session  
$userId = Session::get('UserId'); 

//读取session
$userId = Session::get('UserId');

 

 

当然,应该还有其它办法,欢迎童鞋提成!

 


 

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

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前By尊渡假赌尊渡假赌尊渡假赌
威爾R.E.P.O.有交叉遊戲嗎?
1 個月前By尊渡假赌尊渡假赌尊渡假赌

熱工具

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。