如何设置PHP中SESSION的长期生存时间?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1056个文字,预计阅读时间需要5分钟。
需求背景:用户希望登录后,浏览器能自动记住登录状态,避免每次都需要重新登录。
内容简写:- 用户期望:登录后,浏览器自动保存登录状态,无需每次都手动登录。- Session过期时间:若未设置Session生成时间,则在配置文件中设置Session过期时间。
需求背景:
用户希望他登录之后,浏览器就帮他记住登录状态,这样他就不用每次进入的时候,都需要登录一次。
session过期时间:
如果我们没有设置session的生成时间,在配置文件中默认的生存时间是1440秒
也就是说session的生存时间是24分钟,这里可能有些人会有这样的疑问:
为什么我登录之后,24分钟之后,并没有退出呀?
其实在24分钟之后,session是失效的,为什么用户没有退出是由于php的回收机制造成的。
在配置文件php.ini中,你可以找到这两个配置项,上边的注释基本是一样,大概意思就是说:
"回收机制"在每个session初始化发生是一个概率事件,这个概率是由以下公式得出的:
gc_probability除以gc_divisor。如果gc_probability值为1,gc_divisor值为100,那么触发“回收机制”的概率为1%。
就意味着可能有100次php请求,可能才会有一次触发“回收机制”的可能性。所以说如果session已经过期了,但是没有
触发到“回收机制”,session文件还没有被删除,那session就是还有效的。
如果需要很精准的触发“回收机制”,让session已过期马上删除,就把以上两个值都设置为1.
但是这样会极其影响PHP性能。
本文共计1056个文字,预计阅读时间需要5分钟。
需求背景:用户希望登录后,浏览器能自动记住登录状态,避免每次都需要重新登录。
内容简写:- 用户期望:登录后,浏览器自动保存登录状态,无需每次都手动登录。- Session过期时间:若未设置Session生成时间,则在配置文件中设置Session过期时间。
需求背景:
用户希望他登录之后,浏览器就帮他记住登录状态,这样他就不用每次进入的时候,都需要登录一次。
session过期时间:
如果我们没有设置session的生成时间,在配置文件中默认的生存时间是1440秒
也就是说session的生存时间是24分钟,这里可能有些人会有这样的疑问:
为什么我登录之后,24分钟之后,并没有退出呀?
其实在24分钟之后,session是失效的,为什么用户没有退出是由于php的回收机制造成的。
在配置文件php.ini中,你可以找到这两个配置项,上边的注释基本是一样,大概意思就是说:
"回收机制"在每个session初始化发生是一个概率事件,这个概率是由以下公式得出的:
gc_probability除以gc_divisor。如果gc_probability值为1,gc_divisor值为100,那么触发“回收机制”的概率为1%。
就意味着可能有100次php请求,可能才会有一次触发“回收机制”的可能性。所以说如果session已经过期了,但是没有
触发到“回收机制”,session文件还没有被删除,那session就是还有效的。
如果需要很精准的触发“回收机制”,让session已过期马上删除,就把以上两个值都设置为1.
但是这样会极其影响PHP性能。

