php 如何设置一个严格控制过期时间的session

5年以前  |  阅读数:919 次  |  编程语言:PHP 

1.php session 有效期

PHP的session有效期默认是1440秒(24分钟),如果客户端超过24分钟没有刷新,当前session会被回收,失效。

当用户关闭浏览器,会话结束,session也会失效。

可以修改php.ini的session.gc_maxlifetime来设置session的生命周期,但并不能保证在超过这一时间后session信息立即会删除。因为GC是按机率启动的,可能在某一个长时间内都没有被启动。那么大量的session在超过session.gc_maxlifetime后仍然有效。

2.session.gc_maxlifetime,session.gc_probability,session.gc_divisor说明

session.gc_maxlifetime = 30 表示当session文件在30秒后没有被访问,则视为过期session,等待GC回收。

GC进程调用的概率是通过session.gc_probability/session.gc_divisor计算得来的,而session.gc_divisor默认是1000,

如果session.gc_probability = 1000,那么GC进程在每次执行session_start()时都会调用,执行回收。

把session.gc_probability/session.gc_divisor的机率提高,会有帮助,但会对性能造成严重影响。

3.严格控制session过期方法

1.使用memcache/Redis来保存session,设置过期时间,因为memcache/redis的回收机制不是按机率的,可以确保session过期后失效。

2.只使用php实现,创建一个session类,在session写入时,把过期时间也写入。读取时,根据过期时间判断是否已过期。


    <?php
    /**
     * Session控制类
     */
    class Session{
      /**
       * 设置session
       * @param String $name  session name
       * @param Mixed $data  session data
       * @param Int  $expire 超时时间(秒)
       */
      public static function set($name, $data, $expire=600){
        $session_data = array();
        $session_data['data'] = $data;
        $session_data['expire'] = time()+$expire;
        $_SESSION[$name] = $session_data;
      }
      /**
       * 读取session
       * @param String $name session name
       * @return Mixed
       */
      public static function get($name){
        if(isset($_SESSION[$name])){
          if($_SESSION[$name]['expire']>time()){
            return $_SESSION[$name]['data'];
          }else{
            self::clear($name);
          }
        }
        return false;
      }
      /**
       * 清除session
       * @param String $name session name
       */
      private static function clear($name){
        unset($_SESSION[$name]);
      }
    }
    ?>

demo:


    <?php
    session_start();
    $data = '123456';
    session::set('test', $data, 10);
    echo session::get('test'); // 未过期,输出
    sleep(10);
    echo session::get('test'); // 已过期
    ?>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持脚本之家!

 相关文章:
PHP分页显示制作详细讲解
SSH 登录失败:Host key verification failed
获取IMSI
将二进制数据转为16进制以便显示
获取IMEI
文件下载
贪吃蛇
双位运算符
PHP自定义函数获取搜索引擎来源关键字的方法
Java生成UUID
发送邮件
年的日历图
提取后缀名
在Zeus Web Server中安装PHP语言支持
让你成为最历害的git提交人
Yii2汉字转拼音类的实例代码
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Python 2与Python 3版本和编码的对比
php封装的page分页类完整实例