php实现用户在线时间统计详解

 更新时间:2011年10月08日 19:49:38   作者:  
php实现用户在线时间统计详解,需要的朋友可以参考下。
首先介绍一下所涉及的数据表结构,四个字段:
代码如下:
复制代码 代码如下:

uid<int(10)> :用户id
session_id<varchar(40)> :用户登录后系统产生的session_id,PHP可是使用session_id()函数获取
login_time<int(10)> :登录时间
logout_time<int(10)> :登出时间

1、客户端定时发送请求到服务器端。实现方法是在用户登录后,将uid,session_id,login_time插入一条记录,然后在客户端js设定一个计时器,比如每10分钟向服务器端发送一个请求,以此来达到更新登出时间的目的,当然这个间隔时间设定的越短,数据可能会越准确,不过相应的系统的负载也会越高,这个可以根据实际情况设定一个合适的值。这种方法广泛应用于webgame上,因为webgame的几乎所有请求都是ajax请求,不用刷新页面,一旦刷新页面,这个计时器就失去了价值,这也是这个方法的局限性。

2、务器设定一个定时轮询的脚本。这个方法是在服务器端写一个定时执行的脚本,比如5分钟执行一次,根据数据库中的记录来判断每个会话的 session_id是否还存在于服务器上,如果存在就更新logout_time,不存在就跳过。这样也能比较准确的统计在线时间,不过缺点是需要有服务器的控制权,不然无法设定定时脚本,linux系统可以通过crontab实现,windows系统可以通过计划任务来完成。如果你只是买的虚拟主机,那么这个方法也同样不适合你。

3、在用户每次活动时更新一下登出时间。这样在用户不活动或者退出的时候,登出时间就自然而 然的存在于数据库里了,这也是本文着重讨论的方案。下面给出实现方法。
首先,在用户登录成功后,记录下其uid,session_id,并将现在时间作为登陆时间,现在时间 600s作为登出时间,插入数据库。
代码如下:
复制代码 代码如下:

$uid = $_SESSION[uid] = $info[id];
$session_id = $_SESSION[session_id] = session_id();
$login_time = time();
$logout_time = time() 600;
$sql = "INSERT INTO member_login (uid,session_id,login_time,logout_time) values($uid,$session_id,$login_time,$logout_time)";
mysql_query($sql);

然后在用户每次活动,也就是每点击一个页面时,如果session存在也就是处于登录状态时,更新用户登出时间
代码如下:
复制代码 代码如下:

if($_SESSION[uid]){
$uid = $_SESSION[uid];
$session_id = $_SESSION[session_id];
$logout_time = time() 600;
$sql = "UPDATE member_login SET logout_time=$logout_time WHERE uid=$uid AND session_id=$session_id";
mysql_query($sql);
}

这种方法的优点是相对来说实现起来比较简单,能够适用于大多数的网站,没有额外的服务器需求,而且也可以比较准确的统计用户的在线时间。

缺点也很明显,增加了数据库的更新操作,增加了系统的负载,不过对于中小型网站来说应该不是问题。

相关文章

  • PHP文件操作方法汇总

    PHP文件操作方法汇总

    这篇文章主要介绍了PHP文件操作方法汇总的相关资料,需要的朋友可以参考下
    2015-07-07
  • php抓取https的内容的代码

    php抓取https的内容的代码

    有时候需要获取https网页的内容,下面得方法,可以参考下。
    2010-04-04
  • PHP实现网站应用微信登录功能详解

    PHP实现网站应用微信登录功能详解

    这篇文章主要介绍了PHP实现网站应用微信登录功能,结合实例形式详细分析了php实现微信授权登录功能的具体操作步骤与相关实现技巧,需要的朋友可以参考下
    2019-04-04
  • PHP Laravel门面的实现原理详解

    PHP Laravel门面的实现原理详解

    在Laravel中,门面为应用服务容器中绑定的类提供了一个“静态”接口,使得我们可以不用new这些类出来,就可以直接通过静态接口调用这些类中的方法。本文就来详细聊聊Laravel门面的实现原理,希望对大家有所帮助
    2023-02-02
  • php新建文件的方法实例

    php新建文件的方法实例

    在本篇文章里我们给大家分享的是关于php文件如何新建的实例内容,有需要的朋友们可以参考下。
    2019-09-09
  • php中magic_quotes_gpc对unserialize的影响分析

    php中magic_quotes_gpc对unserialize的影响分析

    这篇文章主要介绍了php中magic_quotes_gpc对unserialize的影响,以实例的形式分析了magic_quotes_gpc安全过滤对unserialize造成的影响以及对此的解决方法,非常具有实用价值,需要的朋友可以参考下
    2014-12-12
  • php中取得URL的根域名的代码

    php中取得URL的根域名的代码

    php中取得URL的根域名的代码,需要的朋友可以参考下。
    2011-03-03
  • php写入、删除与复制文件的方法

    php写入、删除与复制文件的方法

    这篇文章主要介绍了php写入、删除与复制文件的方法,涉及php针对文件常见的操作技巧,需要的朋友可以参考下
    2015-06-06
  • php中的字符编码转换函数用法示例

    php中的字符编码转换函数用法示例

    这篇文章主要介绍了php中的字符编码转换函数用法示例,非常具有实用价值,需要的朋友可以参考下
    2014-10-10
  • PHP图片处理之图片旋转和图片翻转实例

    PHP图片处理之图片旋转和图片翻转实例

    这篇文章主要介绍了PHP图片处理之图片旋转和图片翻转实例,本文使用imagerotate函数实现,自定义了多个函数来实现功能需求,需要的朋友可以参考下
    2014-11-11

最新评论