国内最全IT社区平台 联系我们 | 收藏本站
华晨云阿里云优惠2
您当前位置:首页 > php开源 > DedeCMS > PHPCMS2008记录用户在线登录时间的方法

PHPCMS2008记录用户在线登录时间的方法

来源:程序员人生   发布时间:2013-11-04 04:46:13 阅读次数:2921次

最近找PHPCMS在线时间一直没有找到比较好的解决方案。

因此自己弄了一个,不过还算实用。

方法如下!

1、在phpmyadmin里运行如下SQL语句:

ALTER TABLE `phpcms_member_info` ADD `hdendtime` VARCHAR( 20 ) NOT NULL AFTER `lastlogintime`;
ALTER TABLE `phpcms_member_info` ADD `linetime` VARCHAR( 20 ) NOT NULL AFTER `lastlogintime`;

2、打开includecommon.inc.php

增加如下代码:


if($_userid){//更新在线时间
$time=TIME;
$ist=$db->get_one("SELECT hdendtime FROM `" .DB_PRE ."member_info` WHERE `userid`=$_userid LIMIT 1");//当前时间
$time2=$time-$ist['hdendtime'];
if($time2>60){
$r2 = $db->query("UPDATE `" .DB_PRE ."member_info` SET linetime=linetime+60 ,hdendtime=$time WHERE `userid`=$_userid");
}
}

主要思路是用户点击任意页面运行此语句,当前时间和最后更新的时间差大于60秒的时候就更增加用户在线60秒,用户不点击的时候就无法统计了,我感觉用户不点击的话也没有统计的意义。

3、打开memberadmin emplatesmember_manage.tpl.php
查找第一个<?=$member['username']?>
在后边加上:

在线:<?=ceil($member['linetime']/60)?>分钟

就可以了,大家看看效果吧,有问题联系我哦。

生活不易,码农辛苦
如果您觉得本网站对您的学习有所帮助,可以手机扫描二维码进行捐赠
程序员人生
------分隔线----------------------------
分享到:
------分隔线----------------------------
关闭
程序员人生