简单的数据库统计在线人数
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。
解决方案 »
- 请问怎么更新数据库
- 请问如何按次序调用多个php文件,而且每次都用都需要get传递参数
- 请教关于PHP制作用户登录问题验证是否登录问题??????
- php调用 vb编写的dll 的问题
- 抛砖引玉,我对目前流行的zend framework和pear在概念上有一些混淆
- 刚装Apache+php+mysqpl 不知如何配置Apache,不知如何配置配置C:\Apache2\conf\httpd.conf这个文件。(在线等)
- 如何把php中变量值传到javascript中的变量?并且在javascript中不显示此变量的值
- 哪位高手能说说在php5,默认配置下session到底如何使用?
- 急问:怎样取出下面这个字符串中的两个文件名?
- 一个有关Sql Server的奇怪错误,请高手帮忙
- 怎样实现在线人数统计~!??有些不懂,请教
- 100分求:从把一个Select结果显示在表格中,谢谢,
呵呵。
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."人在线"; ?>