帝国CMS7.0实现记录所有浏览访问的会员的方法

所属分类: CMS教程 / 帝国cms 阅读数: 1693
收藏 0 赞 0 分享

本文以新闻系统数据表为例,讲述帝国CMS7.0实现记录所有浏览访问的会员入数据库的方法。具体步骤如下:

一、新闻系统数据表中字段管理中添加“visituserid”字段,字段类型为“CHAR ”。
 
二、在需要统计的页面的<head></head>中添加如下代码
 

复制代码
代码如下:
<script src="[!--news.url--]/ly/jquery.js" type="text/javascript"></script>
<script>
//信息ID
var id = [!--id--];
//登陆用户
var userid = <?=$lguserid=intval(getcvar('mluserid'))?>;
$(function(){
if(userid)
{
$.post(
'/ly/recorduser/index.php',
{userid:userid,id:id},
"html"
);
}
})
</script>

 
三、添加数据代码
 
可以下载压缩包,将其中的文件夹ly解压后放在根目录中,可以本站下载
 
文件路径 根目录/ly/recorduser/index.php
index.php文件代码:


复制代码
代码如下:
<?php
require('../../e/class/connect.php'); //引入数据库配置文件和公共函数文件
require('../../e/class/db_sql.php'); //引入数据库操作文件
include('../../e/class/functions.php');
$link=db_connect(); //连接MYSQL
$empire=new mysqlquery(); //声明数据库操作类
if(!$_POST['userid'])
{
exit;
}
/*
userid
visituserid
/
表名称:
栏目ID
信息ID
表名称@@@栏目ID@@@信息ID::::::
/
*/
//查询是否已有userid
if($user=$empire->fetch1("select * from {$dbtbpre}ecms_news where id = {$_POST['id']}"))
{
//格式化字符串
$visituserid="{$_POST['userid']}";
//信息分隔符
$dot='';
//判断是否已有记录数
if(strstr($user['visituserid'],$visituserid))
{
//已有记录返回空
die;
}
if($user['visituserid']!='')
{
$dot=',';
}

//大于1000调记录数去掉最后的一条信息
if($user['visituserid'] && substr_count($user['visituserid'],$dot)>=999)
{
//去除最后一条记录数
$arr=explode(',',$user['visituserid']);
$arrvisituserid='';
$dot1=$dot;
for($i=0;$i<count($arr);$i++)
{
if($i!=(count($arr)-1))
{
if($i==(count($arr)-2))
{
$dot1='';
}
$arrvisituserid.=$arr[$i].$dot1;
}
}
$visituserid.=$dot.$arrvisituserid;
}
else
{
$visituserid.=$dot.$user['visituserid'];
}
//不存在的记录数、更新表
$empire->query("update {$dbtbpre}ecms_news set `visituserid` = '{$visituserid}' where id = {$_POST['id']}");
}
//没有记录数插入一条
else
{
$visituserid="{$_POST['userid']}";
$sql=$empire->query(" INSERT INTO `{$dbtbpre}ecms_news` `visituserid` VALUES '{$visituserid}' ");
}
?>

 
四、调用已阅人员列表
 
在需要调用的地方添加代码如下:


复制代码
代码如下:
<div class="ct_fw"><li><b>已阅人:</b></li>
<!--判断visituserid是否为空-->
<?php
if($navinfor[visituserid])
{
?>
<!--visituserid不为空时显示开始-->
<?php
$record=$empire->fetch1("select * from {$dbtbpre}ecms_news where id = $navinfor[id]");
if($record)
{
$info=explode(",",$record['visituserid']);
$visituserid='';
foreach($info as $v)
{
$arr=explode($v);
$sql=$empire->fetch1("select * from {$dbtbpre}enewsmember where userid = $v ");
$visituserid.="<li><a href='/e/space/?userid=$v' title='点击访问{$sql[username]}的空间' target='_blank'>{$sql[username]}</a></li>";
//print_r($arr);
//die;
}
}
?>
<?=$visituserid?>
<!--visituserid不为空时显示结束-->
<?php
}
else
{
?>
<!--visituserid为空时显示开始-->
<!--visituserid为空时显示结束-->
<?php
}
?>
</div>

 
这样就可以了。

 

更多精彩内容其他人还在看

帝国cms的灵动标签判断栏目ID的方法

帝国cms的灵动标签怎么判断栏目ID,需要的朋友可以参考下
收藏 0 赞 0 分享

帝国cms调用会员排行的序号的实现代码

帝国cms调用会员排行的序号的实现代码,需要的朋友可以参考下
收藏 0 赞 0 分享

帝国cms TAGS功能介绍与管理

帝国CMS的tags功能不仅是作为tags信息列表使用,而且是将tags作为自定义分类来使用,可按TAGS调用信息,可以实现碎片同样的功能,只是tags随时都能分类,更加灵活
收藏 0 赞 0 分享

帝国cms 6.6TAGS标签(showtags)调用说明

showtags标签可以通过链接附加参数tempid在标签中设定“标签模板”ID,如何改变整个tags列表页的模板?而不仅仅是改变标签模板
收藏 0 赞 0 分享

帝国cms 搜索关键字调用标签(showsearch)使用说明

本文将详细介绍帝国cms 搜索关键字调用标签(showsearch)使用说明,需要了解的朋友可以参考下
收藏 0 赞 0 分享

给帝国cms 腾讯QQ、淘宝旺旺、微软MSN、谷歌Gtalk 等在线客服增加方法

选择在线状态图片风格、填写QQ号码、在线状态的使用范围(域名)、图片旁的留言、会话权限(一般选择沟通时可使用图片、可发送文件),然后点击“生成网页代码”超低价格,根据提示输入QQ的密码和验证码,然后就会生成代码
收藏 0 赞 0 分享

帝国cms 批量替换字段值使用说明

帝国cms 批量替换字段值为对信息表字段的内容进行批量替换,提高用户工作效率
收藏 0 赞 0 分享

帝国CMS整合Discuz的多种方法详细介绍

帝国CMS整合Discuz有两种方式:方式一、用Ucenter接口整合。使用Ucenter接口整合无需安装通行证跟万能会员接口;方式二、用Discuz通行证接口整合。需先安装万能会员接口,然后再安装通行证
收藏 0 赞 0 分享

帝国CMS自定义JS语句详细整理

大家都知道帝国CMS有一个自定义JS的功能,不知道大家了解吗?这种自定义js常应用于如搜索页面或者其他时时动态显示,虽然有这项功能但由于很多盆友不知道SQL语句,根本无法使用,本文列出常用的语句和大家分享
收藏 0 赞 0 分享

帝国cms签发信息功能使用介绍

本文详细介绍帝国cms签发信息功能使用,需要了解的朋友可以参考下
收藏 0 赞 0 分享
查看更多