页面自动刷新和关闭和判断在线的问题

时间:2021-02-17 23:54:44
1.页面自动更新后,如果发现有新的内容加进来,比如像chinaren一样,别人有

新的短信息发给你,怎么才能发出嘟嘟声提醒用户?
2.用户要关闭一个页面,怎么才能实现先跳出一个确认框,用户确认才关闭
用onunload='return(window.confirm("关闭此窗口你将不能及时知道你的状态和

收到的信息,确定要关闭吗?"));'不行,我试过了!
不要意思似乎都是js的问题~~~~~~~~~~~~~~~
3.怎么样判断用户是否在线?
如果用户登录就将他的id插入到online表,如果他不是按注销来退出,怎么知道

他是否在线上?(登陆时启动一个session,能不能判断这个session存不存在?

5 个解决方案

#1


请各位多多帮忙!

#2


请继续关注!!

#3


1.声音用css实现
2.javascript可以实现
3.php中不能判断session是否存在,你可以作守护进程来定时删除online表中的过期用户

#4


能不能说详细点?摆脱了!

#5


建议你前两个问题到javascript版去问
第三个我有个实例在用
<?
session_start();
$dat_now1=date("H+i+s");//取时间
$p2=explode("+", $dat_now1);
$dat_number1=$p2[0]*3600+$p2[1]*60+$p2[2];//取秒

if($online_time<>"")//上次刷新时间
{$dat_h=substr($online_time,11,2);
$dat_i=substr($online_time,14,2);
$dat_s=substr($online_time,17,2);
$dat_number=$dat_h*3600+$dat_i*60+$dat_s;
}

$tmptime=$dat_number1-$dat_number;//上次到现在的间隔秒数
if(session_is_registered(username)&&(($tmptime>300)||($tmptime<0)))//如果不到5分钟
{
$online_time=date("Y-m-d H:i:s");
$str="replace lt_t_online set lt_username='$username',lt_lasttime=now()";//写入数据库
$res=mysql_query($str);
}
?>
以上文件每分钟自动刷新一次
以下是5分钟运行一次的守护进程
<?
$str = "delete from lt_t_online where UNIX_TIMESTAMP(NOW())-UNIX_TIMESTAMP(lt_lasttime)>300";
mysql_query($str);
?>

#1


请各位多多帮忙!

#2


请继续关注!!

#3


1.声音用css实现
2.javascript可以实现
3.php中不能判断session是否存在,你可以作守护进程来定时删除online表中的过期用户

#4


能不能说详细点?摆脱了!

#5


建议你前两个问题到javascript版去问
第三个我有个实例在用
<?
session_start();
$dat_now1=date("H+i+s");//取时间
$p2=explode("+", $dat_now1);
$dat_number1=$p2[0]*3600+$p2[1]*60+$p2[2];//取秒

if($online_time<>"")//上次刷新时间
{$dat_h=substr($online_time,11,2);
$dat_i=substr($online_time,14,2);
$dat_s=substr($online_time,17,2);
$dat_number=$dat_h*3600+$dat_i*60+$dat_s;
}

$tmptime=$dat_number1-$dat_number;//上次到现在的间隔秒数
if(session_is_registered(username)&&(($tmptime>300)||($tmptime<0)))//如果不到5分钟
{
$online_time=date("Y-m-d H:i:s");
$str="replace lt_t_online set lt_username='$username',lt_lasttime=now()";//写入数据库
$res=mysql_query($str);
}
?>
以上文件每分钟自动刷新一次
以下是5分钟运行一次的守护进程
<?
$str = "delete from lt_t_online where UNIX_TIMESTAMP(NOW())-UNIX_TIMESTAMP(lt_lasttime)>300";
mysql_query($str);
?>