PHP会话提前到期

前端之家收集整理的这篇文章主要介绍了PHP会话提前到期前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我在运行的 PHP站点出现问题,几分钟后用户正在注销(确切的时间因人而异,但频繁出现问题),无论他们是否积极使用该站点或不.

困难在于我无法重现这个问题,如果我使用相同的浏览器以相同的用户身份登录我不会被注销,这表明这不是网站完全被破坏的情况.不幸的是,我无法访问用户计算机来运行任何流量嗅探软件.

我已经检查的东西是:

>要求用户尝试不同的浏览器.这似乎并没有解决问题,也不是一个长期的解决方案,因为我无法决定客户将使用哪些浏览器.
>服务器时间正确且与用户计算机一致.
>用户Apache运行时有权写入会话文件夹,我可以看到正在创建的会话文件及其修改时间正在更新.
>没有使用输出缓冲功能.
>问题出现在各种页面上,似乎没有任何共同之处(即,并非所有页面都使用AJAX,或更新数据库或其他原因).
>用户只能从一台机器上访问他们的帐户,即他们不会在他们的笔记本电脑上做一些工作,切换到桌面,然后想知道为什么他们已经在他们的笔记本电脑上注销了(我们不允许多个同时登录对于同一个用户).

PHP中的会话设置是Debian默认值,并且未在.htaccess文件或其他任何位置更改.主要是:

session.cookie_lifetime    0
session.gc_divisor    100
session.gc_maxlifetime    1440
session.gc_probability    0
session.save_handler    files
session.save_path    /var/lib/PHP5
session.use_cookies    On

Debian通过cron作业删除会话,而不是使用PHP垃圾收集器,这就是为什么gc_probability被设置为0.我们运行的PHP版本是:PHP 5.2.6-1 lenny13与Suhosin-Patch 0.9.6.2(cli)( Lenny的最新版本,我们很快就会升级到Squeeze,但我不认为这是问题的原因).

我们使用Zend_Session来管理会话,并在每个页面上创建一次Zend_Session_Namespace实例,从而自动调用session_start().通过在注销页面调用Zend_Session :: destroy()来清除会话,因此用户应该注销的唯一方法是:

>如果他们明确地单击了注销链接(我们会在发生这种情况时进行记录,并且似乎不会出现浏览预先获取页面并因此将用户注销的情况).
>如果他们让会话处于非活动状态超过24分钟,那么Debian可能会删除他们的会话(有一个cron作业每半小时运行一次,删除所有未经修改超过24分钟的会话).
>如果他们关闭浏览器,将删除其到期时间为0的会话cookie.

查看用户是否已登录的检查是:

>他们有一个有效的会话(通过查看我们是否可以访问$zsession-> user_id进行检查).
>会话表中有一行具有匹配的用户ID和会话ID,这是在不到一小时前最后更新的.我们在注销时删除此行,这样即使会话仍然存在于磁盘上,也没有人可以在不登录的情况下访问该帐户.

任何人都可以提出我可以尝试的其他事情

编辑:我根据评论留下的一些额外的事情:

>设置session.cookie_domain:这似乎在PHP中有非常奇怪的行为.如果我没有设置此变量并将其保留为默认值”(空字符串),则对www.domain.com的请求将生成www.domain.com的cookie.但是,如果我将cookie_domain设置为“www.domain.com”,则cookie的域名为“.www.domain.com”(注意引导点,这意味着对www.domain.com以下的所有内容都有效,例如subsite.www .domain.com).
>设置session.cookie_lifetime:PHP似乎没有更新每个请求的到期时间,因此如果我将cookie_lifetime设置为3600,cookie将在用户首次访问网站后一小时到期,即使他们登录并经常使用它.

编辑2:基于人们提出的其他问题:

>该站点托管在数据中心的单独VLAN中.访问该站点的任何人都不在该站点的同一网络上.
>没有使用IP身份验证,也不会在会话过程的任何部分使用客户端的IP地址(例如,如果用户的下一个请求来自不同的IP,我们不会将会话附加到IP地址并阻止用户).

Debian deletes sessions through a cron job instead of using PHP’s garbage collector

这很奇怪 – 在cron工作中运行的代码是什么?

We delete this row on logout

我建议你在会话过期/删除后2天保留这个(但是在你当前删除它时将其标记为死).此外,开始在Web服务器日志中记录会话ID.

猜你在找的PHP相关文章