四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

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實現用戶在線時間統計詳解,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 郑乙永| 员工的秘密| 简单的公告范文| 唐人街探案网剧第二季| 美女下面| 微信图像男| 尹馨演过的三部电影| 康熙微服第二部免费版第24集| 02j331| 你迷上我 电视剧| 板谷由夏| 视觉暂留现象原理| av电影网| 繁城| 舞蹈生撕腿疼哭视频| 栀子花开电影| 台州林毅| 我的一级兄弟| 小猪佩奇免费版中文第三季| 绿野仙踪电影| 数学二年级上册答案| 神探教授 电视剧| 二年级最佳家长评语| 广西柳州视频共11段| 新三国第95集完整版| 陈永标| 二年级拍手歌生字组词| 江西省旅游地图| 迷宫1意大利劳尔| 愚人节快乐的英文| 罗志祥小猪视频app全部| 我的公公电影| 荒岛大逃亡电影| 电车之狼| 徐蔓华| 采茶舞曲民乐合奏| av电影网| 小淘气尼古拉| 2年级计算题100道题混合| 郑中基的电影全部作品| 台版野浪花原版|