2005-11-16

统计在线人数/用户列表

来源: 本站收集整理 作者:佚名 评论 0 条
 

将以下代码另存为online_list.php(保存前注重修改必要的参数)

<?$host="localhost";//mysql的host
$user="root";//mysql的用户名称
$pw="";//mysql的密码
$db="";//mysql数据库名称
$update_time="30";//更新的频率---秒数
session_start();

if(!$_SESSION['name'])session_register("name");

$con=mysql_connect($host,$user,$pw)or die("连接数据库失败");

$now=time();

mysql_select_db($db,$con)or die("错误的数据库$db");

if(!empty($name)){//假如用户已经登入了

$query=mysql_query("select count(username) from online_list where username='$name'",$con);//查询在线到表是否已经有用户的名称

$result=mysql_result($query,0);//查询的结果

if($result!=0){//假如用户已经在在线列表了

@mysql_query("update online_list set second_time='$now' where username='$name'",$con);//更新用户的最后在线时间

}else{//假如用户已经不在在线列表

@mysql_query("insert into online_list(username,userip,online_time,second_time)values('$name','$REMOTE_ADDR','$now','$now')",$con);//新增一个用户到在线列表

}

}


else{//假如用户没有登入

$query=mysql_query("select count(userip) from online_list where userip='$REMOTE_ADDR'",$con);//查询在线到表是否已经有访客的ip 地址

$result=mysql_result($query,0);//查询的结果

if($result!=0){//假如访客的ip地址已经在在线列表了

@mysql_query("update online_list set second_time='$now' where userip='$REMOTE_ADDR'",$con);//更新访客的最后在线时间

}else{//假如用户列表没有访客的ip地址

@mysql_query("insert into online_list(username,userip,online_time,second_time)values('访客','$REMOTE_ADDR','$now','$now')",$con);//新增一个访客到在线列表

}

}

$del_time=$now-$update_time;

@mysql_query("delete from online_list where second_time<$del_time",$con);//删除在$update_time秒内没有动作的用户

?>


(本文仅表明作者个人观点,不代表本站及其管理员立场.) 推荐 收藏 投稿 打印 返回 关闭
上一篇:格式化显示时间  
下一篇:Discuz!戴志康:和我一样创业的年轻人别浮躁
    评论加载中…
 推荐文章
     

网站首页  -  网站地图 -   站长论坛  -  网站投稿  -    -  网站管理
Copyright © 2008 芜湖站长站 All Rights Reserved 皖ICP备07500611号