帝国CMS二次开发产品或文章浏览记录函数
方法步骤:一:在e/class/userfun.php中加入以下代码:functionuser_SetCook($name,$id,$time=0,$num=10){//cookie名称ID时间戳数量if(!$id){printerror2('不存在的产品记录',$_SERVER['HTTP_REFERER']);}……
方法步骤:
一:在e/class/userfun.php中加入以下代码:
functionuser_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_arras$key=>$val){if(($key<$num)&&$val){$pro.=$val.'|';}}}else{$pro=$prodq;}esetcookie($name,$pro,$time);//esetcookie($name,'',0);//print_r($_COOKIE);}functionuser_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("selectid,title,titlepic,titleurlfrom{$dbtbpre}ecms_{$tbname}whereidin({$jilu_idin})orderbyfind_in_set(id,'{$jilu_idin}')limit{$num}");//按idin里面的排序while($jilu_r=$empire->fetch($sql)){$titleurl=sys_ReturnBqTitleLink($jilu_r);echo'<li><ahref="'.$titleurl.'">'.$jilu_r[title].'</a></li>';//此处是修改样式需要图片自己加}}
二:在内容模版最上面加入以下代码:
<?user_SetCook('cookiepro',$navinfor[id],0,10);//cookie名称可以自己定别重复ID时间戳数量?>
三:在需要显示的地方加入以下代码:
<?=user_GetCook('cookiepro','shop',10);?>//名称数据表名数量
- 上一篇
帝国CMS分类信息有效期
一、有效期 设定分类信息,通常要设定有效期,如:此信息还剩N天 。等等。且大家都在找如何让有效期能根据判断实际,显示天数和是否过期。下面我在分享一下具体操作(我会尽量用最详细的说明)1、在“分类信息模型”
- 下一篇
帝国cms调用当前父栏目的所有子栏目
帝国CMS调用栏目列表的时候常常我们需要让当前的栏目高亮显示!这里我们可以使用灵动标签来实现[e:loop={'selectclassid,classname,classpathfrom[!db.pre!]enewsclasswherebclassid=2orderbyclassid',0,24,0