gpt4 book ai didi

PHP/MySQL 在 session 超时时更新数据库

转载 作者:行者123 更新时间:2023-12-01 00:21:35 25 4
gpt4 key购买 nike

我正在开发“Flash 网站”。在这个程序中,我想添加一个“在线用户”列表,它依赖于 session :当用户登录时启动一个 session ,并在数据库中将用户标记为在线。一旦注销关闭浏览器,用户就会在数据库中被标记为离线。

我知道在关闭浏览器时运行一些函数需要 Javascript,而且它也不安全:如果浏览器崩溃,函数就不会运行。这就是为什么我决定在用户​​注销或用户的 session 超时时更新数据库。

我一直在查找 session 超时,并遇到了这个,以及许多其他类似的标记为重复的问题:How do I expire a PHP session after 30 minutes?

答案方法的问题是;它是一个条件语句,检查用户的最后一个事件是否在 X 秒前,如果没有事件,则超时。在某些网站上有用,但对在线用户列表没用,因为它会在发送新请求时更新,并且在用户关闭浏览器后不会再有任何请求。

其他答案中也提到了 session.gc_maxlifetimesession.cookie_lifetime 的使用,但是 Best answer 指出使用它们是一个坏主意;一种不破坏 session ,只破坏 cookie,另一种是“成本密集型”。

我想要的是用户超时,数据库更新并将用户标记为离线使用 If 条件语句,或者可能使用不同的 If 条件语句,仅必须在用户登录时使用一次,例如计时器或其他东西,并且每当发送请求时,计时器都会重新启动......到目前为止,这些只是我关于如何解决这个问题的想法。

但是,我该怎么做呢?如果答案非常简单明了,我很抱歉,我是 PHP 的新手。

编辑:长话短说:

我想在用户关闭他的浏览器或处于非事件状态 20 分钟后运行一个函数。

澄清...

我想在 20 分钟不活动后更新数据库即使浏览器已关闭。

最佳答案

I want to update the database after 20 minutes of the browser being closed.

我认为关闭浏览器真的不可能(可靠地)。如果他们单击注销按钮,您显然可以运行一些代码来将用户标记为已注销。您可以使用您提到的功能指定 session 适合多长时间,但所有这一切都会使 cookie 在客户端被删除,它不会在服务器端触发任何内容。

您唯一可以做的就是跟踪用户上次事件的时间,如果他们有一段时间没有事件,则假设他们已经离开。因此,只需将一个字段添加到您的用户表并存储他们上次事件的日期时间或 unix 时间戳。然后,您可以每隔几分钟运行一次 cron 作业,将用户标记为已注销,或者您可以简单地修改您的 SQL 查询,以仅提取上次事件时间少于 20 分钟前的用户。

关于PHP/MySQL 在 session 超时时更新数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24713863/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com