简单的数据库统计在线人数 
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。

解决方案 »

  1.   

    http://expert.csdn.net/Expert/topic/2284/2284960.xml?temp=.642605 到这贴去看一下,这问题以前我发过贴
      

  2.   

    可以根据用户的SESSION来记录,可以建一个SESSION表,其中表中的字段如下:session_id ,session_user_id,session_start,session_ip,session_time,session_loginedin,这样就可以用session_loginedin来判断用户当前是否已登录;用session_time记录用户登录的时间(可以在下次登录时提示用户上次访问的时间);可以用session_ip记录用户的IP.
      

  3.   

    sshwsfc(差沙) 贴的是我的代码。我贴过。
    呵呵。
    note.w18.net 用的就是那个方法。
      

  4.   

    http://jueban.ku.net
    看看是不是你要的?
      

  5.   

    当两台机子都打开主页时,怎么始终只在线1人啊??(我用的是sshwsfc(差沙)的代码)
      

  6.   

    http://www.phpx.com/happy/showthread.php?s=&threadid=46235&highlight=%D4%DA%CF%DF%C8%CB%CA%FD
    http://www.phpx.com/happy/showthread.php?s=&threadid=21567
      

  7.   

    谢谢楼上的所有朋友,特别是fufan!!现在我已把这个问题解决了!
      

  8.   

    <?php 
    //利用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."人在线"; ?>