一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - PHP教程 - PHP實現(xiàn)統(tǒng)計在線人數(shù)功能示例

PHP實現(xiàn)統(tǒng)計在線人數(shù)功能示例

2021-03-12 17:24dengwz7788 PHP教程

這篇文章主要介紹了PHP實現(xiàn)統(tǒng)計在線人數(shù)功能,結(jié)合實例形式分析了php基于session對象計算與統(tǒng)計在線人數(shù)的相關(guān)操作技巧,需要的朋友可以參考下

本文實例講述了PHP實現(xiàn)統(tǒng)計在線人數(shù)的方法。分享給大家供大家參考,具體如下:

我記得ASP里面統(tǒng)計在線人數(shù)用application 這個對象就可以了。PHP怎么設(shè)計?

PHP對session對象的封裝的很好,根據(jù)HTTP協(xié)議,每個范圍網(wǎng)站的訪客都可以生成一個唯一的標識符

?
1
2
echo session_id();
//6ed364143f076d136f404ed93c034201<br />

這個就是統(tǒng)計在線人數(shù)的關(guān)鍵所在,只有有這個session_id 也就可以區(qū)分訪問的人了。因為每一個人都不同。
接下來,是怎么把session變量里面的值存到數(shù)據(jù)庫里面去,這里有將介紹另一個函數(shù)

?
1
2
3
4
5
6
7
8
bool session_set_save_handler ( callable $open , callable $close , callable $read , callable $write , callable$destroy , callable $gc )
//callable 可隨時支取的,請求即付的,隨時可償還的
// open(string $savePath, string $sessionName) 打開連接
//close() 關(guān)閉連接
//read(string $sessionId) 對出數(shù)據(jù)
//write(string $sessionId, string $data) //寫入數(shù)據(jù)
//destroy($sessionId) //刪除數(shù)據(jù)
//gc($lifetime) //垃圾回收函數(shù)

注意,上面有幾個函數(shù)是有參數(shù)傳入的,你只要表明有傳送傳入就是的。PHP在執(zhí)行代碼的時候會自動讀取

session中對于的參數(shù)

接下來就是完成上面五個函數(shù)和一個主函數(shù)就可以了

?
1
2
3
4
5
6
7
8
session_set_save_handler(
   array("session","open"),
   array("session","close"),
   array("session","read"),
   array("session","write"),
   array("session","destroy"),
   array("session","gc")
);

主函數(shù)就這樣完成了,但為什么要用array(“session”,"方法")來調(diào)用這些方法,我真心搞不懂

(基本懂了:凡是將對象的方法作為參數(shù)傳遞都需要使用這種形式:array(對象, "方法名"))

接下來就是每個函數(shù)的編寫

?
1
2
3
4
5
6
7
//鏈接數(shù)據(jù)的open
function open($path,$sessname) {
  $db = mysql_connect("localhost","root","123456","test");
  mysql_select_db("test",$db);
  mysql_query("SET NAMES UTF8");
  return true;
}

關(guān)閉數(shù)據(jù)可以鏈接的close

?
1
2
3
4
5
function close(){
$db = mysql_connect("localhost","root","123456","test");
mysql_close($db);
return true;
}

關(guān)鍵函數(shù)要開始了,顯示讀取函數(shù)read(),主要,read()函數(shù)是有值傳進去的,傳入的是session_id

?
1
2
3
4
5
6
function read($sid){
  $sql = "select data from session where sid='{$sid}' and card='".self::$card."'";
  $query = mysql_query($sql) or die(mysql_error());
  $row = mysql_fetch_array($query);
  $row>0?$row["data"]:" ";
}

第二個是寫入函數(shù),如果數(shù)據(jù)庫里面存在的數(shù)據(jù),只要更新時間就可以了,新數(shù)據(jù)寫入

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
function write($sid,$data)
{
   $sql = "select sid from session where sid='{$sid}' and card='".self::$card."'";
   $query = mysql_query($sql) or die(mysql_error());
   $mtime = time();
   $num = mysql_num_rows($query);
   if($num){
    $sql = "UPDATE session SET data='{$data}', mtime ='{$mtime}'";
   }else{
    $sql = "INSERT INTO session (sid,data,mtime,ip,card) VALUES('{$sid}','{$data}','".time()."','{$_SERVER['REMOTE_ADDR']}','".self::$card."')";
   }
   mysql_query($sql);
   return true;
}

接下來就是體現(xiàn)PHP回收機制的函數(shù)了,兩個函數(shù)都有參數(shù)傳入。

?
1
2
3
4
5
6
7
8
9
10
11
function destroy($sid){
  $sql = "DELETE FROM session WHERE sid='{$sid}'";
  mysql_query($sql) or die(mysql_error());
  return true;
}
function gc($max_time){
  $max_time = 600;
  $sql = "DELETE FROM session WHERE `mtime`<'".(time()-$max_time)."'";
  mysql_query($sql) or die(mysql_error());
  return true;
}

好了,五個函數(shù)都完成了,再就是session表中間讀出session的記錄條數(shù)了。就能準確的統(tǒng)計出正在訪問頁面的人數(shù)。

10分鐘沒有操作的用戶記錄將被清空

希望本文所述對大家PHP程序設(shè)計有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 成人福利免费在线观看 | 青青操在线观看 | www.久久av.com | 四虎网站| 男人女人性生活视频 | 激情影院免费 | 美女毛片老太婆bbb80岁 | 日本不卡视频免费 | 日产乱码卡1卡2卡三卡四在线 | 91夜夜人人揉人人捏人人添 | 色欧美在线 | 三级黄色片在线观看 | 四虎在线最新地址公告 | 成人午夜视频一区二区国语 | 亚洲第一天堂无码专区 | 欧美成人第一页 | 人妖女天堂视频在线96 | 婷婷综合久久中文字幕 | 亚洲国产美女精品久久久久 | 婷婷99视频精品全部在线观看 | 欧美一区二区三区在线观看不卡 | 久久精品无码一区二区日韩av | 欧美二区视频 | 亚洲精品一二三四区 | 美女狂揉尿口揉到失禁 | 91庥豆果冻天美精东蜜桃传媒 | 双性小说肉 | jiizz亚洲护士厕所 | 91社区在线观看精品 | 婷婷婷色| 黑人干亚洲人 | 热久久免费视频 | 久久99re2在线视频精品 | 日韩欧美不卡视频 | 日韩经典在线 | 操熟美女又肥又嫩的骚屁股 | 国产成人影院在线观看 | 国产亚洲一区二区三区 | 果冻传媒在线播放1 | 亚洲品质自拍网站 | 2019nv天堂香蕉在线观看 |