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

最近找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)?>分钟

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

相关文章

文章浏览阅读483次。dedecms织梦频道模板中调用栏目分类并排...
文章浏览阅读284次。我们在用织梦建站的过程中,难免会遇到各...
文章浏览阅读152次。seo专题是seo优化必不可少的一环,对于网...
文章浏览阅读142次。在Dedecms中,在列表页调用文章摘要的方...
文章浏览阅读234次。织梦DedeCMS文章内容发布时可以选择“头...
文章浏览阅读701次。虽然织梦DedeCMS因为安全问题被人所诟病...