大家好,所以我有部分工作代码。但是我也有问题。但是让我开始告诉你我想要实现的目标......在我的网站上,我有一个登录工具,它会将所有用户发送到一个主页,并且只有当用户登录时。我想显示还有谁在我的页面上登录,在列表中显示用户名。
我的代码当前能力...
好的,所以我可以对其进行编码以将加入站点的用户添加到数据库中,然后将该数据库上的每个用户显示到一个 div 中,这很棒,因为它可以在线显示每个人......
问题出在哪里...
但是,当用户离开页面时,需要从在线用户数据库中删除用户名。在过去,我会简单地使用 java 中的 on window close 选项来执行此操作。但是由于 Google safari 和 Firefox 不再支持这个选项,我不得不寻找另一种方法。
下面的代码是做什么的...
所以下面的代码会加载一个间隔,所以在很长一段时间后它会重复其中的代码。代码首先将用户添加到数据库中,然后在站点上的列表中显示用户,然后从数据库中删除用户,以防万一他们脱机。
问题出在哪里...
对于一个用户来说,这一切都很好,但是一旦第二个用户参与进来,间隔就会在不同的时间下降。因此,我在显示列表后从数据库中删除了该用户,但这意味着第二个用户显示了数据库,而第一个用户不在其中,因为它们被删除了...如果用户脱机,这也会导致问题尽管功能发生了一半,但它会将它们留在数据库中,并且不会将它们从数据库中删除。
下面是java代码...
$(document).ready(function() {
var user_name = "<?php print $username ?>";
setInterval(function() {
$.post('onlineusers.php', { name: user_name, action:"joined" });
$.post("onlineusers.php", { action2: "list" }, function(data){
$('#listusers').html(data);
});
$.post("onlineusers.php", { nameleft: user_name, action3:"left" }, function(data){
$('#errorrreport').html(data);
});
}, 5000);
}):
现在有PHP文档代码
//------------User joined page put into database --------
if( $_REQUEST["name"])
{
$user_name = $_REQUEST['name'];
};
if( $_REQUEST["action"])
{
$action = $_REQUEST['action'];
};
if ($action == 'joined') {
user_joined($user_name);
};
//-----------Listing online users within page -------------
if( $_REQUEST["action2"])
{
$action2 = $_REQUEST['action2'];
};
if($action2 == 'list') {
foreach (user_list() as $user){
echo $user . "<br />";
};
};
//------------ User left delete from the database ------------
if( $_REQUEST["nameleft"])
{
$user_nameleft = $_REQUEST['nameleft'];
};
if( $_REQUEST["action3"]){
$action3 = $_REQUEST['action3'];
};
if($action3 == 'left') {
user_left($user_nameleft);
};
//------ Functions what to do... --------
function user_joined($user_name) {
$user_name = mysql_real_escape_string(htmlentities($user_name));
mysql_query("INSERT INTO users (user_name)VALUES('$user_name')") or die("this didn't happen");
}
function user_left($user_nameleft) {
$user_name = mysql_real_escape_string(($user_nameleft));
$query = mysql_query("DELETE FROM users WHERE user_name = '$user_nameleft'")or die("failed to delete from table");
}
function user_list() {
$user_list = array();
$users_query = mysql_query("SELECT user_name FROM users") or die ("Unable to collect userlist");
while ($users_row = mysql_fetch_assoc($users_query)){
$user_list[] = $users_row['user_name'];
}
return $user_list;
}
上面的代码
抱歉,由于我多次重新编码以使其正常工作,因此有点混乱。如果有人可以帮助我使其正常工作,我将不胜感激。现在,如果不仅仅是上面的代码,我可以在页面入口处将用户添加到在线用户数据库,并通过列出数据库中的用户来列出经常在线的用户。
真正的问题以及我在哪里寻求您的帮助...
但是,如果您对以下代码有任何想法,那就太好了……离开页面的用户是问题出现的地方。我需要一些方法来检查用户是否仍然处于活动状态,如果他们没有从数据库中删除它们,那么当列表刷新时,用户不再在列表中。例如 ping 某些东西直到它没有响应并从数据库中删除用户。
由于我当前的代码存在多个用户和间隔函数同步的问题,因此需要考虑到不同的用户会在不同的时间看到列表刷新。
PS 我也看过使用 $SESSION 但是我仍然不确定如何通过检查离线用户然后从数据库中删除它们来完成这项工作,这可能是一种方法。
谢谢,我希望有足够的信息继续下去。