服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服务器之家 - 编程语言 - PHP教程 - 也谈php网站在线人数统计

也谈php网站在线人数统计

2019-10-28 13:23php教程网 PHP教程

db层: db_online.PHP //该函数使用户自己在线,并且检查其他用户的在线情况

function checkOnline($userid,$tempid=null)      
{      
$conn = connect();      

//对于所有用户      
//先设置自己为在线      
$stmt = "UPDATE ".DB_NAME.".USER SET IsOnline='Y' WHERE UserID=".$userid;      
$result = query($stmt,$conn);      
//info($stmt);      
//如果当前用户是游客      
if ($tempid != null)      
{      
$stmt = "SELECT TempID FROM ".DB_NAME.".TEMPUSER WHERE     

TempID=".$tempid;      
$result = query($stmt,$conn);      
//info($stmt);      
//如果该游客还在线      
if ($row = fetch_array($result))      
{      
$stmt = "UPDATE ".DB_NAME.".TEMPUSER SET     

RequestTime='".getCurrentTime()."' WHERE TempID=".$tempid;      
$result = query($stmt,$conn);      
//info($stmt);      
}      
//该游客已经离线      
else      
{      
$stmt = "INSERT INTO ".DB_NAME.".TEMPUSER     

VALUES('".$tempid."','".getCurrentTime()."')";      
$result = query($stmt,$conn);      
//info($stmt);      
}      
}      

//查看其他用户      
//普通用户      
$stmt = "UPDATE ".DB_NAME.".USER SET IsOnline='N' WHERE ".time()." -     

unix_timestamp(RequestTime) > ".ONLINE_DURATION." AND UserGroupID != ".GUEST;      
$result = query($stmt,$conn);      

//游客      
$stmt = "DELETE FROM ".DB_NAME.".TEMPUSER WHERE ".time()." -     

unix_timestamp(RequestTime) > ".ONLINE_DURATION;      
$result = query($stmt,$conn);      
disconnect($conn);      
}      

//得到在线人数,分用户和游客      
function getOnlineNumber()      
{      
$olnum = array();      
$conn = connect();      
$stmt = "SELECT COUNT(UserID) FROM ".DB_NAME.".USER WHERE IsOnline='Y' AND     

UserGroupID != 4"; //4 为guest的用户组id      
//info ($stmt);      
$result = query($stmt,$conn);      
$olnum['user'] = result($result,0,"COUNT(UserID)");      
$stmt = "SELECT COUNT(TempID) FROM ".DB_NAME.".TEMPUSER";      
//info ($stmt);      
$result = query($stmt,$conn);      
if ($row = fetch_array($result))      
{      
$olnum['guest'] = $row['COUNT(TempID)'];      
}      
disconnect($conn);      
return $olnum; //from www.w3sky.com     
}      

      

其中的connect(), disconnect(), query(),fetch_array()函数在dbmanager.inc.PHP中      
dbmanager.inc.PHP      

define("DB_NAME","databasename");      
define("DB_USER","user");      
define("DB_PASS","pass");      
define("DB_HOST","localhost");      

function connect()      
{      
//echo "Connecting to Host:".HOST."<br>";      
$conn = mysql_connect(DB_HOST,DB_USER,DB_PASS);      
mysql_select_db(DB_NAME);      
/*     
if ($conn)     
{     
echo "Connect to database sucessfully. connection id:".$conn."<br>";     
}     
else     
{     
echo "Connect to database failed.<br>";     
}     
*/      
return $conn;      
}      

function pconnect()      
{      
return mysql_pconnect(DB_HOST,DB_USER,DB_PASS);      
}      

function disconnect($conn)      
{      
$close = mysql_close($conn);      
/*     
if ($close)     
echo "MySQL Database disconnected.<br>";     
else     
echo "MySQL Database disconnecting failed. Please try again.<br>";     
*/      
}      

function query($stmt,$conn)      
{      
return mysql_query($stmt,$conn); //from www.w3sky.com     
}      

function fetch_array($result)      
{      
return mysql_fetch_array($result);      
}      

function fetch_row($result)      
{      
return mysql_fetch_row($result);      
}      

function num_rows($result)      
{      
return mysql_num_rows($result);      
}      

function result($result,$row,$field)      
{      
return mysql_result($result,$row,$field);      
}      

    
rule层:      
rl_online.PHP      
function getOnline()      
{      
if ($userid == 2)      
{      
if (session_is_registered("tempuserid"))      
{      
checkOnline($userid,$tempuserid);      
}      
}      
else      
{      
checkOnline($userid);      
}      
return getOnlineNumber();      
}      

ui层:      
ui_online.PHP      
$online_num = getOnline();      
echo "在线人数,注册用户".$online_num['user']."人,游客".$online_num['guest']."人"; 

延伸 · 阅读

精彩推荐
  • PHP教程PDO::commit讲解

    PDO::commit讲解

    今天小编就为大家分享一篇关于PDO::commit讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧...

    php参考手册4952019-06-27
  • PHP教程PHP获取星期几的常用方法小结

    PHP获取星期几的常用方法小结

    这篇文章主要介绍了PHP获取星期几的常用方法,结合实例形式分析了php使用date函数获取指定日期星期几的具体操作技巧与相关注意事项,需要的朋友可以参考...

    天涯海角路4272019-07-16
  • PHP教程PHP通过文件路径获取文件名的实例代码

    PHP通过文件路径获取文件名的实例代码

    在本篇技术文章中我们给大家带来的是PHP如何通过文件路径获取文件名的实例内容,对此有需要的朋友们可以学习下。...

    你看我哪里像好人4652019-09-02
  • PHP教程PHP内置函数生成随机数实例

    PHP内置函数生成随机数实例

    在本篇文章里小编给大家分享了关于PHP内置函数生成随机数实例内容,对此有兴趣的朋友们可以学习下。...

    laozhang3982019-06-30
  • PHP教程对于Laravel 5.5核心架构的深入理解

    对于Laravel 5.5核心架构的深入理解

    安装完laravel框架后,我们就需要了解一下整个框架的核心架构,下面这篇文章主要给大家介绍了关于Laravel 5.5核心架构的一些深入理解,文中通过图文及示...

    郁冬1672019-10-21
  • PHP教程php的命名空间与自动加载实现方法

    php的命名空间与自动加载实现方法

    这篇文章主要给大家介绍了关于php的命名空间与自动加载实现方法,文中通过示例代码介绍的非常详细,对大家学习或者使用php具有一定的参考学习价值,...

    什么都只会一点点4792019-08-28
  • PHP教程php+js实现裁剪任意形状图片

    php+js实现裁剪任意形状图片

    这篇文章主要为大家详细介绍了php+js实现裁剪任意形状图片,类似css mask,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    coder_daiwang4332019-08-30
  • PHP教程PHP+redis实现的购物车单例类示例

    PHP+redis实现的购物车单例类示例

    这篇文章主要介绍了PHP+redis实现的购物车单例类,涉及php连接、操作redis数据库及购物车功能相关定义与使用技巧,需要的朋友可以参考下...

    梦屿千寻-不忘初心2312019-06-21