我目前正在使用这个php代码来计算当前在线的用户数量:
$session_id = session_id();
$time_stamp = time();
$time_limit = $time_stamp - 300; // We give the session only 5 minutes if it exists
$result = $this->select("SELECT * FROM `online_visitors` WHERE `session_id`='$session_id' LIMIT 1");
if (!mysql_num_rows($result)) {
$tb_col[0] = "visitor_ip";
$tb_col[1] = "country";
$tb_col[2] = "session_id";
$tb_col[3] = "time_stamp";
$tb_col[4] = "last_time_stamp";
$tb_data[0] = "'" . $this->visitor_ip . "'";
$tb_data[1] = "'" . $this->visitor_country . "'";
$tb_data[2] = "'" . $session_id . "'";
$tb_data[3] = "'" . $time_stamp . "'";
$tb_data[4] = "'" . $time_stamp . "'";
$this->insert("`online_visitors`", $tb_col, $tb_data);
} else {
$this->update("`online_visitors`", "`visitor_ip`='$this->visitor_ip', `country`='$this->visitor_country', `last_time_stamp`='$time_stamp'", "`session_id`='$session_id'");
}
$this->delete("`online_visitors`", "`last_time_stamp`<'$time_limit'");
但它不会实时更新。我想每30秒检查一次用户数量。我可能还想将此表连接到jQuery heartbeat函数,以便更可靠地了解当前有多少用户在线。
我是否正确地处理了这个问题?关于如何在jQuery中实现这一点,有什么建议吗(我不太擅长)?或者我的方法可以改进吗?
我还想改进我的php代码
您也可以用另一种方法来实现这一点:您不需要通过ajax更新时间,而是假设用户在离开页面或关闭浏览器之前一直处于在线状态。在这种情况下,您使用ajax将用户设置为离线,并在浏览器启动后执行。在极少数情况下(停电、系统崩溃),不会触发此事件,因此最好检查上次更新的时间,以防您有浮动用户。