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

发布时间:2022-04-30 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了php 如何设置一个严格控制过期时间的session脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

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写入时,把过期时间也写入。读取时,根据过期时间判断是否已过期。

brush:PHp;">
@H_512_35@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]);
  }
}
?>

脚本宝典总结

以上是脚本宝典为你收集整理的php 如何设置一个严格控制过期时间的session全部内容,希望文章能够帮你解决php 如何设置一个严格控制过期时间的session所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。