帮助中心 >  技术知识库 >  网站相关 >  建站知识 >  帝国CMS获取产品或文章浏览记录的方法

帝国CMS获取产品或文章浏览记录的方法

2016-12-03 18:48:28 15941

帝国CMS获取产品或文章浏览记录的方法


这篇文章主要为大家介绍了帝国CMS获取产?或文章浏览记录的方法,通过一个自定义函?实现获取产品或文章浏览记录的功能,是非常实用的技巧,对于进行帝国CMS二次开发具有一定的参考借鉴价值,需要的朋友可以参考下

本文实例讲述了帝国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建站有所帮助。



提交成功!非常感谢您的反馈,我们会继续努力做到更好!

这条文档是否有帮助解决问题?

非常抱歉未能帮助到您。为了给您提供更好的服务,我们很需要您进一步的反馈信息:

在文档使用中是否遇到以下问题: