php语言

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

时间:2024-07-25 19:13:35 php语言 我要投稿
  • 相关推荐

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

  PHP的session有效期默认是1440秒(24分钟),如果客户端超过24分钟没有刷新,当前session会被回收,失效。下面是小编为大家带来的php如何设置一个严格控制过期时间的session的知识,欢迎阅读。

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


【php如何设置一个严格控制过期时间的session】相关文章:

教你如何使用php的session07-13

PHP语言中Session的概念08-03

php语言中session用法07-02

php实现Session存储到Redis08-17

PHP解决session死锁的解决方法09-17

php中Session存储到Redis的方法09-23

PHP创建和使用session cookie变量05-16

如何利用PHP时间转换Unix时间戳代码10-21

如何使用PHP计算时间差07-20

php与mysql时区设置的总结10-01