帝国CMS7.0实现记录所有浏览访问的会员的方法
本文以新闻系统数据表为例,讲述帝国CMS7.0实现记录所有浏览访问的会员入数据库的方法。具体步骤:
一、新闻系统数据表中字段管理中添加“visituserid”字段,字段类型为“CHAR ”。
二、在需要统计的页面的<head></head>中添加代码:
<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><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' />
这样就可以了。
声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至201542412@QQ.com举报,一经查实,本站将立刻删除。
相关推荐
-
帝国cms用sql语句批量替换字段里面的内容包括专题替换方法
帝国cms替换替换有两种方式,1.后台栏目-批量替换字段,这个有一些麻烦。2.就是用SQL语句、在后台执行位置:系统→备份与恢复数据→执行SQL语句。优点方便高效,替换后后需要全部生成一遍再可以。
-
帝国cms灵动标签调用友情链接的代码
用灵动标签调用首页的友情链接,标签中的20为要循环调用的数量,可以根据自己需求修改。
-
帝国cms统计某一个数据表的文章信息数量的方法
下面是统计nws表的24发布文章收录和一个月的更新数量代码如下:
-
帝国cms如何调用某个栏目下信息id在区间1-100间的文章方法
帝国程序调用某个栏目下信息id在区间1-100间的文章,灵动标签如何写,其实这个很简单,主要就是数据库SQL调用的方式
-
帝国cms判断字段为空列表页的list.var写法
帝国cms判断字段为空列表页的list.var写法