第一
种方法即设置php.ini配置文件,设置session.gc_maxlifetime和session.cookie_lifetime节\x0d\x0a\x0d\x0a点属性值,当然也可以使用ini_set
函数改变当前上下文环境的属性值:\x0d\x0a\x0d\x0aini_set('session.gc_maxlifetime',"3600")//秒\x0d\x0aini_set("session.cookie_lifetime","3600")//秒\x0d\x0a\x0d\x0a第二种方法即设置Session
时间戳,比如下面的办法。\x0d\x0a\x0d\x0a在登录成功时设置时间戳为当前时间推后1小时,$_SESSION['expiretime']=time()+3600。在\x0d\x0a\x0d\x0a检查用户登录情况使用如下代码:\x0d\x0a\x0d\x0aif(isset($_SESSION['expiretime'])){\x0d\x0aif($_SESSION['expiretime']
回答于 2022-12-14可以在PHP中,设置php.ini,找到session.gc_maxlifetime
=
1440
#(PHP5默认24分钟)
这里你可以随便设置一下过期时间.但是有人说设置以后,好象不起作用!
其实不是不起作用,而是因为系统默认:
session.gc_probability
=
1
session.gc_divisor
=
1000
以上设置的
1/1000就是session
1000次才有一次被回收。
只要你的访问量大了,那就能达到回收的效果.
或者你也可以设置一下session.gc_divisor
的值,
比如:session.gc_divisor
=
1,这样就能明显的看到SESSION过期的效果了.
session_set_cookie_params()此函数即可,设置保存session_id的cookie存活时间,即session的存活时间,如果cookie被禁止了,可把session进行托管,使用session_set_save_handler()即可,session_id可保存在memcache中或者数据库中
评论列表(0条)