关于php session自动失效的问题

在一个使用session来实现的用户验证页面中,发呆时间半小时左右再刷新就发现已经退出登陆了

察看php的文档时看到session的cookie确省设置应该是没有时间限制的。

搜索了一下web,原来session还有一个服务器端的垃圾回收机制,确省配置在24分钟就清楚用户session数据

ubuntu的LAMP缺省安装下,php.ini中有如下配置:

; After this number of seconds, stored data will be seen as 'garbage' and
; cleaned up by the garbage collection process.
session.gc_maxlifetime = 1440

1440s = 24分钟后,用户session即失效。

解决办法可以参考后面参考链接,有详细的介绍

简单的解决办法:

在需要长时间保持连接的页面增加 iframe 引用一个自动刷新页面

< iframe  id ="div_refresh"  width ="0"  height ="0"  src ="refresh.php" ></ iframe >

refresh.php内容如下:

<? php
if  ( ! isset ( $_SESSION )) {
  
session_start ();
}
?>
< html >
< head >
< meta http - equiv = " Content-Type "  content = " text/html; charset=gb2312 "   />
< meta http - equiv = " refresh "  content = " 300 "   />
</ head >
< body >
</ body >
</ html >

参考链接:

http://blog.centresource.com/2006/05/23/php-session-lifetime-an-adventure/ 

http://blog.serv.idv.tw/2005/05/05/233/

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值