重庆分公司,新征程启航

为企业提供网站建设、域名注册、服务器等服务

php在线人数数据库设计 php统计在线人数

php 如何做在线人数统计

两种方案:1,每上线一个人就向数据库写入一次数据,然后定期做回收。2,利用数据库储存session。目前看来,第二种更简单实用

成都做网站、成都网站建设的开发,更需要了解用户,从用户角度来建设网站,获得较好的用户体验。创新互联建站多年互联网经验,见的多,沟通容易、能帮助客户提出的运营建议。作为成都一家网络公司,打造的就是网站建设产品直销的概念。选择创新互联建站,不只是建站,我们把建站作为产品,不断的更新、完善,让每位来访用户感受到浩方产品的价值服务。

PHP中如何实现在线人数的统计和显示

要使用数据库,建立一个表,比如名字是online,至少有以下列:

name_ip 存放登录用户名,未登录的存放IP,char类型

url 存放每个页面的地址,char类型

last_time 存放刷新页面的最后时间,int类型

表的主键是:name_ip+url

每个页面一开始就要刷新这个表,使用的SQL是:

$name_ip='用户名或者IP';//你能搞定

$url=$_SERVER["PHP_SELF"];

$time=time();

$sql="replace delayed into online (name_ip,url,last_time) values ('$name_ip','$url',$time)";

mysql_query($sql);

获取某页面在线人数的查询是语句

$limit=time()-10*60;//10分钟内访问的认为在线,10分钟*60秒/分钟

$sql="select count(*) from online where url='$url' and last_time=$limit";

$res=mysql_query($sql);

list($online_count)=mysql_fetch_row($res);

mysql_free_result($res);

echo "本页面在线人数: $online_count";

PHP 在线人数统计 我的想法:建一个在线用户数据表。

“用户退出或者关闭浏览器SESSION消失的时候在线用户表删除相对应的数据”

这里不可行。。服务器没办法获取这个信息的。都是被动请求的。

要换个思路,要用js或者其它方式定时触发删除。。

一般15分钟或者30分钟。。

数据库还要记录IP,记录最近一次触发时间。

PHP+MYSQL实例--网站在线人数的程序统计代码

首先是创建MYSQL数据库表。

CREATE TABLE tablename (

field type(max_length) DEFAULT 'default_value' (NOT) NULL

}

可以使用的SQL语句。

CREATE TABLE useronline (

timestamp int(15) DEFAULT '0' NOT NULL,

ip varchar(40) NOT NULL,

file varchar(100) NOT NULL,

PRIMARY KEY (timestamp),

KEY ip (ip),

KEY file (file)

);

下面我们开始使用PHP脚本,首先定义MYSQL的信息。

server = "localhost"; //你的服务器

db_user = "root"; //你的mysql的用户名

db_pass = "password"; //你的mysql的密码

database = "users"; //表的名字

设置统计的时间(多少秒内在线人数)

timeoutseconds = 300;

取当前时间。

timestamp = time();

我想用php制作一个在线聊天室,怎么统计在线人数啊?

根据会话数来统计在线人数.

一般是这样的,在数据库中记录每个用户的会员数据,并且用户的每一次动作都update他的最后动作时间.那么统计在线人数就是统计某段时间内有动作的用户即可.一般5分钟或者10分钟.

上面是靠用户自己的操作来更新在线时间的.你也可以在用户停留的页面弄个JS,隔个2分钟就做个ajax请求,自动更新用户的最后的在线时间,

ps 如果你不想修改session存到mysql,memcached等里面,则可以根据session_id()来获取PHPSESSID来作为身份标识,

然后要在程序中写上随机删除过期很久了的会话.

至于聊天记录.你肯定是要保存在服务器端的,至于读取.可以通过AJAX几秒来获取一次数据库里面的内容,当然,在获取记录的时候,你需要记录你获取的时间,然后下次获取的时候只呀这个时间后的,如果有数据,则追加到当前聊天记录后面,否则保持不变.

PHP如何统计在线人数

原理:根据不同的IP统计出当前有多少人在线。

实现方式:可以用数据库,也可以用文本。

我这里用了文本实现。

$user_online = "count.php"; // 保存人数的文件

touch ( $user_online ); // 如果没有此文件,则创建

$timeout = 30; // 30秒内没动作者,认为掉线

$user_arr = file_get_contents ( $user_online );

$user_arr = explode ( '#', rtrim ( $user_arr, '#' ) );

print_r ( $user_arr );

$temp = array ();

foreach ( $user_arr as $value ) {

$user = explode ( ",", trim ( $value ) );

if (($user [0] != getenv ( 'REMOTE_ADDR' ))  ($user [1]  time ())) { // 如果不是本用户IP并时间没有超时则放入到数组中

array_push ( $temp, $user [0] . "," . $user [1] );

}

}

array_push ( $temp, getenv ( 'REMOTE_ADDR' ) . "," . (time () + ($timeout)) . '#' ); // 保存本用户的信息

$user_arr = implode ( "#", $temp );

// 写入文件

$fp = fopen ( $user_online, "w" );

flock ( $fp, LOCK_EX ); // flock() 不能在NFS以及其他的一些网络文件系统中正常工作

fputs ( $fp, $user_arr );

flock ( $fp, LOCK_UN );

fclose ( $fp );

echo "当前有" . count ( $temp ) . "人在线";


分享题目:php在线人数数据库设计 php统计在线人数
本文网址:http://cqcxhl.com/article/hjschj.html

其他资讯

在线咨询
服务热线
服务热线:028-86922220
TOP