搜索
首页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脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

安全考试浏览器

安全考试浏览器

Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器