| 作者: | jjdai (jjdai) | | 圖 | | 時間: | 2007-11-13 00:23:51 | | 來源: | 61.230.199.61 |
| | 此文: | | 點閱: | 1761 | | 回覆: | 0 |
| [WEB][PHP] 關於線上人數統計的實做.
如果網頁是使用 PHP 來寫的話,可以很容易做到基本的統計網站人數功能。
1. 去改寫 session 的處理方式,例如以下是將原本存到 file 的 session 資料變成
   存到 MySql之類的 (memory) db. (不想搞變化的話直接去存 session file 的目錄
   和子目錄中數數看有幾個檔案即可知道有幾條現存的連線):
   去用 session_set_save_handler() 函式改寫 session 在
   open(),
   close(),
   read(),
   write(),
   destroy(),
   Gc()
   時的處理方式。
   其中在 read() 時去更新目前的 timestamp 值;Gc() 時去檢查該 session 是否
   已經超過時間了(),超過者即刪除之,現存數量即為目前連線數。
   (有些細節請到網路上找相關資料)
2. 讓連到網站的連線被紀錄 session:
   也就是在 xxx.php 中執行「session_start();」。
3. 預設的連線保留時間是設定在 php.ini 的 「session.gc_maxlifetime」欄位,
   又其預設值是 1440 秒,也就是說一個 session 超過約 24 分鐘沒有動作的話,
   "可能" 會被移除 (這裡講的是 "可能",因為垃圾收集機制不是每一次都會作用
   的,網站越熱門的,其狀態越正確。See Also: session.gc_probability,
   session.gc_divisor)。
   經由上述變化處理,就可以很容易達成類似 BBS 的連線統計功能,可以有來源 IP,
   連線數, idle 時間, ... 等 ,結果呈現可以參考以下 URL:
   http://career.zhupiter.com/account/usrlst.php
關鍵字: PHP, session_set_save_handler(), Database session, MySQL, 實做, 線上人數統計, file session
--
jjdai
(C) Copy Rights Reserved.
(Modified by [jjdai] from 61.230.199.61 at 2007-11-13 00:24:47)
(Modified by [jjdai] from 61.230.199.61 at 2007-11-13 00:25:27)
|