php實(shí)現(xiàn)用戶在線時(shí)間統(tǒng)計(jì)詳解
更新時(shí)間:2011年10月08日 19:49:38 作者:
php實(shí)現(xiàn)用戶在線時(shí)間統(tǒng)計(jì)詳解,需要的朋友可以參考下。
首先介紹一下所涉及的數(shù)據(jù)表結(jié)構(gòu),四個(gè)字段:
代碼如下:
uid<int(10)> :用戶id
session_id<varchar(40)> :用戶登錄后系統(tǒng)產(chǎn)生的session_id,PHP可是使用session_id()函數(shù)獲取
login_time<int(10)> :登錄時(shí)間
logout_time<int(10)> :登出時(shí)間
1、客戶端定時(shí)發(fā)送請(qǐng)求到服務(wù)器端。實(shí)現(xiàn)方法是在用戶登錄后,將uid,session_id,login_time插入一條記錄,然后在客戶端js設(shè)定一個(gè)計(jì)時(shí)器,比如每10分鐘向服務(wù)器端發(fā)送一個(gè)請(qǐng)求,以此來(lái)達(dá)到更新登出時(shí)間的目的,當(dāng)然這個(gè)間隔時(shí)間設(shè)定的越短,數(shù)據(jù)可能會(huì)越準(zhǔn)確,不過相應(yīng)的系統(tǒng)的負(fù)載也會(huì)越高,這個(gè)可以根據(jù)實(shí)際情況設(shè)定一個(gè)合適的值。這種方法廣泛應(yīng)用于webgame上,因?yàn)閣ebgame的幾乎所有請(qǐng)求都是ajax請(qǐng)求,不用刷新頁(yè)面,一旦刷新頁(yè)面,這個(gè)計(jì)時(shí)器就失去了價(jià)值,這也是這個(gè)方法的局限性。
2、務(wù)器設(shè)定一個(gè)定時(shí)輪詢的腳本。這個(gè)方法是在服務(wù)器端寫一個(gè)定時(shí)執(zhí)行的腳本,比如5分鐘執(zhí)行一次,根據(jù)數(shù)據(jù)庫(kù)中的記錄來(lái)判斷每個(gè)會(huì)話的 session_id是否還存在于服務(wù)器上,如果存在就更新logout_time,不存在就跳過。這樣也能比較準(zhǔn)確的統(tǒng)計(jì)在線時(shí)間,不過缺點(diǎn)是需要有服務(wù)器的控制權(quán),不然無(wú)法設(shè)定定時(shí)腳本,linux系統(tǒng)可以通過crontab實(shí)現(xiàn),windows系統(tǒng)可以通過計(jì)劃任務(wù)來(lái)完成。如果你只是買的虛擬主機(jī),那么這個(gè)方法也同樣不適合你。
3、在用戶每次活動(dòng)時(shí)更新一下登出時(shí)間。這樣在用戶不活動(dòng)或者退出的時(shí)候,登出時(shí)間就自然而 然的存在于數(shù)據(jù)庫(kù)里了,這也是本文著重討論的方案。下面給出實(shí)現(xiàn)方法。
首先,在用戶登錄成功后,記錄下其uid,session_id,并將現(xiàn)在時(shí)間作為登陸時(shí)間,現(xiàn)在時(shí)間 600s作為登出時(shí)間,插入數(shù)據(jù)庫(kù)。
代碼如下:
$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);
然后在用戶每次活動(dòng),也就是每點(diǎn)擊一個(gè)頁(yè)面時(shí),如果session存在也就是處于登錄狀態(tài)時(shí),更新用戶登出時(shí)間
代碼如下:
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);
}
這種方法的優(yōu)點(diǎn)是相對(duì)來(lái)說實(shí)現(xiàn)起來(lái)比較簡(jiǎn)單,能夠適用于大多數(shù)的網(wǎng)站,沒有額外的服務(wù)器需求,而且也可以比較準(zhǔn)確的統(tǒng)計(jì)用戶的在線時(shí)間。
缺點(diǎn)也很明顯,增加了數(shù)據(jù)庫(kù)的更新操作,增加了系統(tǒng)的負(fù)載,不過對(duì)于中小型網(wǎng)站來(lái)說應(yīng)該不是問題。
代碼如下:
復(fù)制代碼 代碼如下:
uid<int(10)> :用戶id
session_id<varchar(40)> :用戶登錄后系統(tǒng)產(chǎn)生的session_id,PHP可是使用session_id()函數(shù)獲取
login_time<int(10)> :登錄時(shí)間
logout_time<int(10)> :登出時(shí)間
1、客戶端定時(shí)發(fā)送請(qǐng)求到服務(wù)器端。實(shí)現(xiàn)方法是在用戶登錄后,將uid,session_id,login_time插入一條記錄,然后在客戶端js設(shè)定一個(gè)計(jì)時(shí)器,比如每10分鐘向服務(wù)器端發(fā)送一個(gè)請(qǐng)求,以此來(lái)達(dá)到更新登出時(shí)間的目的,當(dāng)然這個(gè)間隔時(shí)間設(shè)定的越短,數(shù)據(jù)可能會(huì)越準(zhǔn)確,不過相應(yīng)的系統(tǒng)的負(fù)載也會(huì)越高,這個(gè)可以根據(jù)實(shí)際情況設(shè)定一個(gè)合適的值。這種方法廣泛應(yīng)用于webgame上,因?yàn)閣ebgame的幾乎所有請(qǐng)求都是ajax請(qǐng)求,不用刷新頁(yè)面,一旦刷新頁(yè)面,這個(gè)計(jì)時(shí)器就失去了價(jià)值,這也是這個(gè)方法的局限性。
2、務(wù)器設(shè)定一個(gè)定時(shí)輪詢的腳本。這個(gè)方法是在服務(wù)器端寫一個(gè)定時(shí)執(zhí)行的腳本,比如5分鐘執(zhí)行一次,根據(jù)數(shù)據(jù)庫(kù)中的記錄來(lái)判斷每個(gè)會(huì)話的 session_id是否還存在于服務(wù)器上,如果存在就更新logout_time,不存在就跳過。這樣也能比較準(zhǔn)確的統(tǒng)計(jì)在線時(shí)間,不過缺點(diǎn)是需要有服務(wù)器的控制權(quán),不然無(wú)法設(shè)定定時(shí)腳本,linux系統(tǒng)可以通過crontab實(shí)現(xiàn),windows系統(tǒng)可以通過計(jì)劃任務(wù)來(lái)完成。如果你只是買的虛擬主機(jī),那么這個(gè)方法也同樣不適合你。
3、在用戶每次活動(dòng)時(shí)更新一下登出時(shí)間。這樣在用戶不活動(dòng)或者退出的時(shí)候,登出時(shí)間就自然而 然的存在于數(shù)據(jù)庫(kù)里了,這也是本文著重討論的方案。下面給出實(shí)現(xiàn)方法。
首先,在用戶登錄成功后,記錄下其uid,session_id,并將現(xiàn)在時(shí)間作為登陸時(shí)間,現(xiàn)在時(shí)間 600s作為登出時(shí)間,插入數(shù)據(jù)庫(kù)。
代碼如下:
復(fù)制代碼 代碼如下:
$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);
然后在用戶每次活動(dòng),也就是每點(diǎn)擊一個(gè)頁(yè)面時(shí),如果session存在也就是處于登錄狀態(tài)時(shí),更新用戶登出時(shí)間
代碼如下:
復(fù)制代碼 代碼如下:
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);
}
這種方法的優(yōu)點(diǎn)是相對(duì)來(lái)說實(shí)現(xiàn)起來(lái)比較簡(jiǎn)單,能夠適用于大多數(shù)的網(wǎng)站,沒有額外的服務(wù)器需求,而且也可以比較準(zhǔn)確的統(tǒng)計(jì)用戶的在線時(shí)間。
缺點(diǎn)也很明顯,增加了數(shù)據(jù)庫(kù)的更新操作,增加了系統(tǒng)的負(fù)載,不過對(duì)于中小型網(wǎng)站來(lái)說應(yīng)該不是問題。
您可能感興趣的文章:
- php流量統(tǒng)計(jì)功能的實(shí)現(xiàn)代碼
- php下用cookie統(tǒng)計(jì)用戶訪問網(wǎng)頁(yè)次數(shù)的代碼
- php實(shí)現(xiàn)統(tǒng)計(jì)網(wǎng)站在線人數(shù)的方法
- php利用cookie實(shí)現(xiàn)訪問次數(shù)統(tǒng)計(jì)代碼
- php使用Session和文件統(tǒng)計(jì)在線人數(shù)
- 也談php網(wǎng)站在線人數(shù)統(tǒng)計(jì)
- PHP實(shí)現(xiàn)統(tǒng)計(jì)在線人數(shù)功能示例
- php簡(jiǎn)單統(tǒng)計(jì)在線人數(shù)的方法
- PHP實(shí)現(xiàn)簡(jiǎn)單網(wǎng)站訪客統(tǒng)計(jì)的方法實(shí)例
相關(guān)文章
利用PHP+JS實(shí)現(xiàn)搜索自動(dòng)提示(實(shí)例)
本篇文章對(duì)利用PHP+JS實(shí)現(xiàn)搜索自動(dòng)提示的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06
PHP使用ODBC連接數(shù)據(jù)庫(kù)的方法
這篇文章主要介紹了PHP使用ODBC連接數(shù)據(jù)庫(kù)的方法,涉及php使用ODBC操作數(shù)據(jù)庫(kù)的基本技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07
學(xué)習(xí)php設(shè)計(jì)模式 php實(shí)現(xiàn)備忘錄模式(Memento)
這篇文章主要介紹了php設(shè)計(jì)模式中的備忘錄模式,使用php實(shí)現(xiàn)備忘錄模式,感興趣的小伙伴們可以參考一下2015-12-12
PHP簡(jiǎn)單實(shí)現(xiàn)文本計(jì)數(shù)器的方法
這篇文章主要介紹了PHP簡(jiǎn)單實(shí)現(xiàn)文本計(jì)數(shù)器的方法,涉及PHP針對(duì)文本文件的簡(jiǎn)單判斷,讀取及寫入等操作技巧,需要的朋友可以參考下2016-04-04
Thinkphp框架開發(fā)移動(dòng)端接口(2)
這篇文章主要介紹了thinkphp框架開發(fā)移動(dòng)端接口的第2種方法,實(shí)現(xiàn)移動(dòng)端訪問自動(dòng)切換移動(dòng)主題模板,從而實(shí)現(xiàn)偽app訪問,感興趣的小伙伴們可以參考一下2016-08-08
php中如何同時(shí)使用session和cookie來(lái)保存用戶登錄信息
本篇文章是對(duì)在php中同時(shí)使用session和cookie來(lái)保存用戶登錄信息的實(shí)現(xiàn)代碼進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-07-07
PHP在不同頁(yè)面間傳遞Json數(shù)據(jù)示例代碼
本文為大家介紹下PHP如何在不同頁(yè)面間傳遞Json數(shù)據(jù),具體實(shí)現(xiàn)如下,感興趣的朋友可以參考下哈,希望對(duì)大家有所幫助2013-06-06

