侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

PHP实现统计在线人数的方法

php  /  管理员 发布于 7年前   340

PHP对session对象的封装的很好,根据HTTP协议,每个范围网站的访客都可以生成一个唯一的标识符

echo session_id();//6ed364143f076d136f404ed93c034201<br />

这个就是统计在线人数的关键所在,只有有这个session_id 也就可以区分访问的人了。因为每一个人都不同。

接下来,是怎么把session变量里面的值存到数据库里面去,这里有将介绍另一个函数

bool session_set_save_handler ( callable $open , callable $close , callable $read , callable $write , callable$destroy , callable $gc )//callable 可随时支取的,请求即付的,随时可偿还的// open(string $savePath, string $sessionName) 打开连接//close() 关闭连接//read(string $sessionId) 对出数据//write(string $sessionId, string $data) //写入数据//destroy($sessionId) //删除数据//gc($lifetime) //垃圾回收函数

注意,上面有几个函数是有参数传入的,你只要表明有传送传入就是的。PHP在执行代码的时候会自动读取

session中对于的参数

接下来就是完成上面五个函数和一个主函数就可以了

session_set_save_handler(   array("session","open"),   array("session","close"),   array("session","read"),   array("session","write"),   array("session","destroy"),   array("session","gc"));

主函数就这样完成了.

注意:凡是将对象的方法作为参数传递都需要使用这种形式:array(对象, "方法名")

接下来就是每个函数的编写

//链接数据的openfunction open($path,$sessname) {  $db = mysql_connect("localhost","root","123456","test");  mysql_select_db("test",$db);  mysql_query("SET NAMES UTF8");  return true;}

关闭数据可以链接的close

function close(){$db = mysql_connect("localhost","root","123456","test");mysql_close($db);return true;}

关键函数要开始了,显示读取函数read(),主要,read()函数是有值传进去的,传入的是session_id

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"]:" ";}

第二个是写入函数,如果数据库里面存在的数据,只要更新时间就可以了,新数据写入

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;}

接下来就是体现PHP回收机制的函数了,两个函数都有参数传入。

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;}

好了,五个函数都完成了,再就是session表中间读出session的记录条数了。就能准确的统计出正在访问页面的人数。

10分钟没有操作的用户记录将被清空。

精确的通过php实现统计在线人数的方法的代码:

<?php$filename='online.txt';//数据文件$cookiename='VGOTCN_OnLineCount';//cookie名称$onlinetime=600;//在线有效时间,单位:秒 (即600等于10分钟)   $online=file($filename);//PHP file() 函数把整个文件读入一个数组中。与 file_get_contents() 类似,不同的是 file() 将文件作为一个数组返回。数组中的每个单元都是文件中相应的一行,包括换行符在内。如果失败,则返回 false$nowtime=$_SERVER['REQUEST_TIME'];$nowonline=array();//得到仍然有效的数据foreach($online as $line){  $row=explode('|',$line);  $sesstime=trim($row[1]);  if(($nowtime - $sesstime)<=$onlinetime){//如果仍在有效时间内,则数据继续保存,否则被放弃不再统计    $nowonline[$row[0]]=$sesstime;//获取在线列表到数组,会话ID为键名,最后通信时间为键值  }}/*@创建访问者通信状态使用cookie通信COOKIE 将在关闭浏览器时失效,但如果不关闭浏览器,此 COOKIE 将一直有效,直到程序设置的在线时间超时*/if(isset($_COOKIE[$cookiename])){//如果有COOKIE即并非初次访问则不添加人数并更新通信时间  $uid=$_COOKIE[$cookiename];}else{//如果没有COOKIE即是初次访问  $vid=0;//初始化访问者ID  do{//给用户一个新ID    $vid++;    $uid='U'.$vid;  }while(array_key_exists($uid,$nowonline));  setcookie($cookiename,$uid);}$nowonline[$uid]=$nowtime;//更新现在的时间状态//统计现在在线人数$total_online=count($nowonline);//写入数据if($fp=@fopen($filename,'w')){  if(flock($fp,LOCK_EX)){    rewind($fp);    foreach($nowonline as $fuid=>$ftime){      $fline=$fuid.'|'.$ftime."\n";      @fputs($fp,$fline);    }    flock($fp,LOCK_UN);    fclose($fp);  }}echo 'document.write("'.$total_online.'");';

相关推荐:

PHP视频教程:https://www.php.cn/course/list/29/type/2.html

以上就是PHP实现统计在线人数的方法的详细内容,更多请关注其它相关文章!


  • 上一条:
    PHP一些实用小技巧
    下一条:
    总结PHP编程20大效率要点
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 用Time Warden监控PHP中的代码处理时间(0个评论)
    • 在PHP中使用array_pop + yield实现读取超大型目录功能示例(0个评论)
    • Property Hooks RFC在PHP 8.4中越来越接近现实(0个评论)
    • 近期文章
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • Laravel 11.15版本发布 - Eloquent Builder中添加的泛型(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-11
    • 2017-12
    • 2018-01
    • 2018-02
    • 2018-03
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-09
    • 2021-02
    • 2021-03
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    • 2024-05
    • 2024-06
    • 2024-07
    • 2024-09
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客