简单的数据库统计在线人数
PHP源码:--------------------------------------------------------------------------------
function online() {
global $REMOTE_ADDR;
$timestamp = time();
$datafile = mysql_query("select * from online");
while($array=mysql_fetch_array($datafile)) {
if($array[time] < ($timestamp-300) || $array[ip]==$REMOTE_ADDR) mysql_query("delete from online where ip='$array[ip]'");
}
mysql_query("insert into online values('','$REMOTE_ADDR','$timestamp')");
mysql_query("OPTIMIZE TABLE `online`");
$online=mysql_fetch_array(mysql_query("select count(id) from online"));
Return $online[0];
}
//引用的时候直接令$online=online()即可得到在线人数。时限为5分钟。
//首先在mysql里面建立一个online表,三个字段,第一个是自增长的id,第二//个是ip,第三个是time。
PHP源码:--------------------------------------------------------------------------------
function online() {
global $REMOTE_ADDR;
$timestamp = time();
$datafile = mysql_query("select * from online");
while($array=mysql_fetch_array($datafile)) {
if($array[time] < ($timestamp-300) || $array[ip]==$REMOTE_ADDR) mysql_query("delete from online where ip='$array[ip]'");
}
mysql_query("insert into online values('','$REMOTE_ADDR','$timestamp')");
mysql_query("OPTIMIZE TABLE `online`");
$online=mysql_fetch_array(mysql_query("select count(id) from online"));
Return $online[0];
}
//引用的时候直接令$online=online()即可得到在线人数。时限为5分钟。
//首先在mysql里面建立一个online表,三个字段,第一个是自增长的id,第二//个是ip,第三个是time。
呵呵。
note.w18.net 用的就是那个方法。
看看是不是你要的?
http://www.phpx.com/happy/showthread.php?s=&threadid=21567
//利用session_id来解决LAN的问题
session_start();//首先你要有读写文件的权限
//本程序可以直接运行,第一次报错,以后就可以$online_log = "count.dat"; //保存人数的文件,
$timeout = 30;//30秒内没动作者,认为掉线
$entries = file($online_log); $temp = array(); for ($i=0;$i<count($entries);$i++) {
$entry = explode(",",trim($entries[$i]));
if (($entry[0] != session_id()) && ($entry[1] > time())) {
array_push($temp,$entry[0].",".$entry[1]."\n"); //取出其他浏览者的信息,并去掉超时者,保存进$temp
}
} array_push($temp,session_id().",".(time() + ($timeout))."\n"); //更新浏览者的时间
$users_online = count($temp); //计算在线人数$entries = implode("",$temp);
//写入文件
$fp = fopen($online_log,"w");
flock($fp,LOCK_EX); //flock() 不能在NFS以及其他的一些网络文件系统中正常工作
fputs($fp,$entries);
flock($fp,LOCK_UN);
fclose($fp); echo "当前有".$users_online."人在线"; ?>