首先我們找到論壇首頁網站模板的處理程序頁面,source/module/forum/forum_index.php 找到如下代碼:
- $onlineinfo = explode(" ", $_G['cache']['onlinerecord']);
- if(empty($_G['cookie']['onlineusernum'])) {
- $onlinenum = DB::result_first("SELECT count(*) FROM ".DB::table('common_session'));
- if($onlinenum > $onlineinfo[0]) {
- $onlinerecord = "$onlinenum ".TIMESTAMP;
- DB::query("UPDATE
".DB::table('common_setting')." SET svalue='$onlinerecord' WHERE
skey='onlinerecord'"); - save_syscache('onlinerecord', $onlinerecord);
- $onlineinfo = array($onlinenum, TIMESTAMP);
- }
- dsetcookie('onlineusernum', intval($onlinenum), 300);
- } else {
- $onlinenum = intval($_G['cookie']['onlineusernum']);
- }
這裏$onlineinfo 為在線信息的緩存記錄,如果此值為空,則查詢 common_session 表,讀取在線人數的緩存。如果當前人數大於緩存最高在線人數,則更新 common_setting 表的最高在線記錄人數,並緩存。如果有在線人數記錄則直接讀取在線人數。
如果後台開啓了現實在線人數,則處理在線現會員信息。
- $_G['setting']['maxonlinelist'] = $_G['setting']['maxonlinelist'] ? $_G['setting']['maxonlinelist'] : 500;
在此程序對默認顯示的在線人數默認限定為500;
- $query = DB::query("SELECT uid, username, groupid, invisible, lastactivity, fid FROM ".DB::table('common_session')." WHERE uid>'0' LIMIT ".$_G['setting']['maxonlinelist']);
- while($online = DB::fetch($query)) {
- $membercount ++;
- if($online['invisible']) {
- $invisiblecount++;
- continue;
- } else {
- $online['icon']
= !empty($_G['cache']['onlinelist'][$online['groupid']]) ?
$_G['cache']['onlinelist'][$online['groupid']] :
$_G['cache']['onlinelist'][0]; - }
- $online['lastactivity'] = dgmdate($online['lastactivity'], 't');
- $whosonline[] = $online;
- }
這裏通過 common_session 表的查詢,搜索出最近在線的顯示會員,這裏排除了 invisible 的隱身會員。
- if(isset($_G['cache']['onlinelist'][7]) && $_G['setting']['maxonlinelist'] > $membercount) {
- $query = DB::query("SELECT uid,
username, groupid, invisible, lastactivity, fid FROM
".DB::table('common_session')." WHERE uid='0' ORDER BY uid DESC LIMIT
".($_G['setting']['maxonlinelist'] - $membercount)); - while($online = DB::fetch($query)) {
- $online['icon'] = $_G['cache']['onlinelist'][7];
- $online['username'] = $_G['cache']['onlinelist']['guest'];
- $online['lastactivity'] = dgmdate($online['lastactivity'], 't');
- $whosonline[] = $online;
- }
- }
這裏如果在最大在線人數大於當前在線會員,這剩餘的部分通過遊客補全。
- if($onlinenum > $_G['setting']['maxonlinelist']) {
- $membercount = $discuz->session->onlinecount(1);
- $invisiblecount =
DB::result_first("SELECT COUNT(*) FROM ".DB::table('common_session')."
WHERE invisible = '1'"); - }
- if($onlinenum < $membercount) {
- $onlinenum = $discuz->session->onlinecount(0);
- dsetcookie('onlineusernum', intval($onlinenum), 300);
- }
- $guestcount = $onlinenum - $membercount;
以上代碼的意思是,如果在線人數> 最大顯示在線人數,則重新統計在線會員人數。
一旦在線人數< 在線會員數,則重新統計所有在線會員數 (包括隱身) 並寫入緩存。
最後由在線總人數和在線會員數得出在線遊客。