在 PHP 和 MySQL 中确定用户在线状态
利用会话跟踪,本文旨在建立一种有效的方法来确定用户的在线状态
搭载会话
虽然搭载 PHP 会话提供了一种方便的解决方案,但它依赖于时间戳和超时。为了避免这些限制,我们探索了一种以跟踪用户活动为中心的替代方法。
基于数据库的跟踪
在数据库的“Users”表中,创建一个“lastActiveTime” ” 捕获用户上次交互时间的字段。通过不断更新该字段,您可以通过查询指定时间范围(例如过去五分钟)内“lastActiveTime”的用户来确定用户的在线状态。
避开时区
为了简化该过程,请使用服务器的时间(通过 MySQL 的 NOW() 函数),而不是尝试考虑时区。这种方法提供了一种实时跟踪活跃用户的可靠方法。
不断更新
如果跟踪连续活动是必要的,您可以实现一个 JavaScript 脚本来发送每分钟“ping”一次到您的服务器。这将更新用户活动记录,而无需持续浏览页面。
更新的代码片段
以下更新的代码片段利用 fetch 并承诺处理“ping”请求:
<code class="javascript">(async function ping() { // Asynchronously call stillAlive.php await fetch("stillAlive.php"); // Issue this call again in 60 seconds setTimeout(ping, 60_000); }());</code>
以上是如何在PHP和MySQL中高效跟踪用户在线状态?的详细内容。更多信息请关注PHP中文网其他相关文章!