帝国CMS获取产品或文章浏览记录的方法
帝国CMS获取产品或文章浏览记录的方法
发布时间:2016-12-23 来源:查字典编辑
摘要:本文实例讲述了帝国CMS获取产品或文章浏览记录的方法。分享给大家供大家参考。具体如下:方法步骤如下:一、在e/class/userfun.p...

本文实例讲述了帝国CMS获取产品或文章浏览记录的方法。分享给大家供大家参考。具体如下:

方法步骤如下:

一、在e/class/userfun.php中加入以下代码:

function user_SetCook($name,$id,$time=0,$num=10){//cookie名称 ID 时间戳 数量

if(!$id){

printerror2('不存在的产品记录',$_SERVER['HTTP_REFERER']);

}

$prodq=$id.'|';

$projilu=getcvar($name);

if($projilu){

$prozuhe=$prodq.$projilu;//把新浏览的放在第一

$pro_arr=explode('|',$prozuhe);

$new_arr=array_merge(array_unique($pro_arr));//去除重复,重新索引下标

foreach($new_arr as $key=>$val){

if(($key<$num) && $val){

$pro.=$val.'|';

}

}

}else{

$pro=$prodq;

}

esetcookie($name,$pro,$time);

//esetcookie($name,'',0);

//print_r($_COOKIE);

}

function user_GetCook($name,$tbname,$num=10){ //名称 数据表 数量

global $empire,$dbtbpre;

if(preg_match("/^[0-9|]+$/",getcvar($name))){

$jilu_all=substr(getcvar($name),0,-1); //1|2|3

$jilu_idin=str_replace('|',',',$jilu_all);//1,2,3

}else{

$jilu_idin=0;//避免sql错误没有返回0

}

$sql=$empire->query("select id,title,titlepic,titleurl from {$dbtbpre}ecms_{$tbname} where id in ({$jilu_idin}) order by find_in_set(id,'{$jilu_idin}') limit {$num}"); //按id in 里面的排序

while($jilu_r=$empire->fetch($sql))

{

$titleurl=sys_ReturnBqTitleLink($jilu_r);

echo '<li><a href="'.$titleurl.'">'.$jilu_r[title].'</a></li>';//此处是修改样式需要图片自己加

}

}

二、在内容模版最上面加入以下代码:

<?php

user_SetCook('cookiepro',$navinfor[id],0,10);//cookie名称可以自己定别重复 ID 时间戳 数量

?>

三:在需要显示的地方加入以下代码:

<?=user_GetCook('cookiepro','shop',10);?>

其中:

cookiepro为名称

shop为数据表名

10为调用数量

希望本文所述对大家的帝国CMS建站有所帮助。

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新帝国cms学习
热门帝国cms学习
CMS教程子分类