当前位置: 首页 > 图文教程 > 网络编程 > PHP > 精确到每一秒钟 如何实现在线人数的显示?

PHP
IIS+mysql+php学习
PEAR MDB 数据库抽象层 ?? 一次编写?随处运行
数据库设计技巧(二)
数据库设计技巧(三)
PHP中通过ADO调用Access数据库
从 MySQL 导入导出大量数据的程序实现方法
MySQL中修改密码及访问限制设置详解
数据库设计范式
MySQL 查询中的分页思路的优化
Adodb 官方介绍
PHP中 ADOdb 类库介绍(二)
PHP中 ADOdb 类库介绍(一)
MySQL中各种字段的取值范围
数据库设计技巧(一)
为数据库建立索引(一)
为数据库建立索引(二)
用 PHP 实现 XML 备份 Mysql 数据库
mysql常见出错代码
浅谈php+mysql身份验证的方法
apache服务器配置全攻略

PHP 中的 精确到每一秒钟 如何实现在线人数的显示?


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 77 ::
收藏到网摘: n/a

【PHPChina讯】

<?php
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)&brvbar;&brvbar;($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);

原文地址:http://www.phpchina.com/?4148/action_viewspace_itemid_3418.html