博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Discuz在线人数统计原理-个人分析
阅读量:5825 次
发布时间:2019-06-18

本文共 2765 字,大约阅读时间需要 9 分钟。

Discuz在线人数统计原理-个人分析

 

eluban论坛在线人数统计原理

2013-5-6

一、基本原理(流程)

 

 

1、读取和生成在线人数

用户每次进入首页,会读取COOKIE中的$_DCOOKIE['onlineusernum'](在线人数cookie值,此cookie包括会员和游客)。

[a]、如果【有】,这个值就去取,然后直接显示。

[b]、如果【没有】,系统就会分别统计表cdb_sessions中“会员(已登录)”和“游客(没有登录)”的人数。并创建$_DCOOKIE['onlineusernum']注意:此cookie时间只有5分钟。如果过了5分钟,用户再次进入首页,则需要重新到数据库获取并重新创建cookie。五分钟时间刚好,DZ这种做法可以有效的缓解服务器的压力。

 

会员在cdb_sessions表中会记录用户的IPusernameuid

游客在cdb_sessions表的usernameuid为空,仅记录IP,以此来区分。

 

[c]、另外论坛在线人数统计还受“在线保持时间”控制,如图:

 

“在线保持时间”是指:用户过了这个设定的值没有活动,然后其他任何一用户任一操作都会使系统自动将表cdb_sessions中此用户的数据删除。注意:只是删除此用户在首页显示的在线状态,不是已退出网站(即此用户还是登录状态)。

 

2、更新用户状态

用户每刷新一次页面(包括打开任何一个新页面),系统都会修改表cdb_sessions中的lastactivity(最后活动时间)字段和action(当前操作代号)等。比如:会员是根据usernameuid进行修改。游客是根据IP进行修改。

 

3、用户退出处理

用户点击“退出”,系统会删除cdb_sessions中此账号对应的sessions信息。

注意:直接关闭浏览器、直接清除浏览器cookie或长时间没有操作页面。cdb_sessions表中这些用户会根据“在线保持时间”来处理。

如果当前时间  最后活动时间lastactivity >在线保持时间,系统自动删除cdb_sessions表中此用户数据。

如果当前时间  最后活动时间lastactivity <=在线保持时间,

cdb_sessions表中如果【有】此用户信息就修改此用户的最后活动时间lastactivity

cdb_sessions表中如果【没有】此用户信息就添加一条此用户认证信息。

 

二、数据库

数据库类有专门的一张表记录当前在线用户的登录状态(表:cdb_sessions

 

 

各字段释义如下:

cdb_sessions    会员认证表

sid    char    SID

ip1    tinyint    IP

ip2    tinyint    IP

ip3    tinyint    IP

ip4    tinyint    IP

uid    mediumint    会员ID

username    char    会员名

groupid    smallint    会员组

styleid    smallint    风格ID

invisible    tinyint    是否隐身登录

action    tinyint    当前动作

lastactivity    int    最后活动时间

lastolupdate    int    最后更新时间

pageviews    smallint    页面访问量

seccode    smallint    记录验证码

fid    smallint    论坛ID

tid    mediumint    主题ID

bloguid    mediumint    正在浏览的文集

 

三、代码

1、  控制处理代码(根目录index.php220行左右)

 

 
  1. <?php 
  2.         if(empty($_DCOOKIE['onlineusernum'])) { 
  3.             $onlinenum = $db->result_first("SELECT COUNT(*) FROM {$tablepre}sessions"); 
  4.             if($onlinenum > $onlineinfo[0]) { 
  5.                 $_DCACHE['settings']['onlinerecord'] = $onlinerecord = "$onlinenum\t$timestamp"
  6.                 $db->query("UPDATE {$tablepre}settings SET value='$onlinerecord' WHERE variable='onlinerecord'"); 
  7.                 require_once DISCUZ_ROOT.'./include/cache.func.php'
  8.                 updatesettings(); 
  9.                 $onlineinfo = array($onlinenum$timestamp); 
  10.             } 
  11.             dsetcookie('onlineusernum'intval($onlinenum), 300); 
  12.         } else { 
  13.             $onlinenum = intval($_DCOOKIE['onlineusernum']); 
  14.         } 
  15.         $onlineinfo[1] = gmdate($dateformat$onlineinfo[1] + ($timeoffset * 3600)); 
  16.  
  17. ?> 

2、  模板循环显示代码(模板根目录discuz.htm290行左右)

 

 
  1. <ul class="userlist"> 
  2. <!--{if $whosonline}--> 
  3.     <!--{loop $whosonline $key $online}--> 
  4.         <li title="{lang time}: $online[lastactivity]{LF} {lang action}: $online[action] <!--{if $online['fid']}-->{LF}{lang forum}: $online[fid]<!--{/if}-->"> 
  5.         <img src="images/common/$online[icon]" alt="" /> 
  6.         <!--{if $online['uid']}--> 
  7.             <a href="space.php?uid=$online[uid]">$online[username]</a> 
  8.         <!--{else}--> 
  9.             $online[username] 
  10.         <!--{/if}--> 
  11.         </li> 
  12.     <!--{/loop}--> 
  13. <!--{else}--> 
  14.     <li style="width: auto">{lang online_only_guests}</li> 
  15. <!--{/if}--> 
  16. </ul> 

 

 

      本文转自许琴 51CTO博客,原文链接:http://blog.51cto.com/xuqin/1194265,如需转载请自行联系原作者

你可能感兴趣的文章
CRM Transaction处理中的权限控制
查看>>
在PL/SQL中获取操作系统环境变量
查看>>
[转]linux创建链接文件的两种方法
查看>>
python ipaddress模块使用
查看>>
统计文件里面某个字符串出现次数
查看>>
FHS
查看>>
文件权限
查看>>
云从科技发布3D结构光人脸识别技术
查看>>
busybox里的僵尸进程为何那么多
查看>>
appium自动化属性使用一
查看>>
python debug
查看>>
mkisofs
查看>>
java 连接数据库之一个完整的函数
查看>>
centos5.6下virtualbox安装手记
查看>>
mysql脚本
查看>>
OllyDBG 入门系列教学--让你瞬间成为破解高手
查看>>
jQuery插件开发的准备
查看>>
Dubbo点滴(2)之集群容错
查看>>
Zend Framework 自动加载类的实现方法
查看>>
7月24日云栖精选夜读:未来的超级智能网络攻击需要AI竞技俱乐部来拯救
查看>>