帝国cms字段处理函数

前言:增加/修改字段时可以设置“后台增加信息处理函数”、“后台修改信息处理函数”、“前台增加信息处理函数”、“前台修改信息处理函数”,可以分别设置对字段内容处理的函数,对于对字段内容存放格式有特殊要求的模型用得比较多。今天我们再简单讲解下处理函数制作格式。

一、前言:

 一、7.0版本的数据库配置文件是哪个文件?

基本设置步骤:1、编写处理函数;2、将函数复制到e/class/userfun.php文件内容里;3、修改字段设置处理函数名称。字段处理函数格式:

帝国CMS提供了强大的自定义字段处理函数功能,极大的方便了用户对帝国CMS进行二次开发!

7.0版本数据库配置文件:/e/config/config.php
6.6及以下版本数据库配置文件:/e/class/config.php
 
 
二、忘记后台登陆认证码怎么办?
查看 /e/config/config.php
文件里的“$ecms_config[‘esafe’][‘loginauth’]”变量内容。
 
 
三、不想显示后台的“商城”菜单,如何操作?
答:后台>系统>系统参数设置>模型设置:“关闭后台菜单”项勾选“商城”即可。
 
 
四、更换了栏目目录地址,为什么信息页地址不更新?
答:因为7.0直接将地址存在数据库里,所以更换目录规则后,需到:后台>系统>数据更新>更新信息页地址:更新数据表中的内容页地址。(注:看左侧菜单,非“数据更新中心”页面里)
 
 
五、如何关闭动态页面模板在线修改
答:如果不想开启在后台修改动态页面模板,可以修改 /e/config/config.php
文件里的“$ecms_config[‘esafe’][‘openeditdttemp’]”变量值为0。
 
 
六、专题评论表单
答:专题评论访问地址 /e/pl/?doaction=dozt&classid=专题ID
专题的评论表单需增加:<input type=”hidden” name=”doaction”
value=”dozt”> <input type=”hidden” name=”classid”
value=”专题ID”>
 
 
七、为什么“更新专题”页面不显示专题?
答:因为“更新专题”页面是为没有管理专题权限的用户而设计的单独管理专题功能。管理员可以在增加专题时设置“可更新专题的用户”,这样即使没有管理专题权限,也可以在更新专题页面对专题进行管理与更新。授权更方便。
 
 
八、为什么评论页的评分功能不能使用?
答:如果是要使用评分功能的模型,要往模型数据表增加“infopfen”(评分数)和“infopfennum”(评分人数)两个字段,详细操作步骤:
    后台>系统>管理数据表>管理字段>增加字段:
   
评分数字段:字段名填“infopfen”、字段标识填“评分数”、字段类型选“大数值型(INT)”,其他默认,点提交;
   
评分人数字段:字段名填“infopfennum”、字段标识填“评分人数”、字段类型选“大数值型(INT)”,其他默认,点提交;
    两个字段增加后模型即可使用评分功能。
 
 
九、7.0版本如何调用专题的信息?
答:调用专题的信息要改用“索引灵动标签”(e:indexloop)调用。
[e:indexloop={索引分类ID,显示条数,操作类型,栏目ID,系统模型ID,附加SQL条件}]
模板代码内容
[/e:indexloop]
 
 
十、如何调用专题的推荐信息?
答:“索引灵动标签”的“附加SQL条件”设置:
    所有推荐信息用:’isgood>0′
    二级推荐的信息用:’isgood=2′
 
 
十一、如果栏目的信息数显示不对,如何处理?
答:可以到后台>系统>数据更新>数据更新中心>更新栏目信息数。
 
 
十二、多值字段如何调用?
答:多值字段存放方式:多个值之间用“||||||”分隔、值里的各个选项之间用“::::::”分隔。下面为内容模板中显示多值字段例子:
<?php
$morefr=explode(‘||||||’,$navinfor[字段名]);
$mfcount=count($morefr);
for($mfi=0;$mfi<$mfcount;$mfi++)
{
$morefrf=explode(‘::::::’,$morefr[$mfi]);
?>
选项1:<?=$morefrf[0]?>
选项2:<?=$morefrf[1]?>
选项3:<?=$morefrf[2]?>
选项4:<?=$morefrf[3]?>
……
<?php
}
?>
 
 
十三、“信息处理结果反馈给会员”在哪儿设置?
答:修改信息就可以看到设置选项。
 
 
十四、为什么用SQL调用不能加“checked=1”条件?
答:因为7.0版本的待审核信息与发布信息单独表存放,所以调用前台信息不再需要checked=1条件,效率更高。只需将此SQL条件删除即可。
 
 
十五、专题页面有哪些PHP变量?
答:当前专题ID或当前专题子类ID变量为“$GLOBALS[‘navclassid’]”。
当为专题子类页面时,则所属专题ID变量为“$GLOBALS[‘navinfor’][‘ecmsbid’]”,当等于0时就是专题页,更容易识别专题页与专题子类页。
 
 
十六、刷新所有信息内容页面时提示“Table ‘*.phome_ecms_news_data_’
doesn’t exist”
答:原因是数据本身有问题,信息索引表phome_ecms_表名_index有不存在ID的记录。
解决办法:进数据库删除索引表中不存在的ID记录即可解决。也可以在数据更新最下面清理

functionuser_FieldFun($mid,$f,$isadd,$isq,$value,$cs){return$value;}

帝国CMS在增加/修改字段时可以设置“后台增加信息处理函数”、“后台修改信息处理函数”、“前台增加信息处理函数”、“前台修改信息处理函数”,可以分别设置对字段内容处理的函数,对于对字段内容存放格式有特殊要求的模型用得比较多。今天我们来简单讲解下处理函数制作格式。字段处理函数的具体设置位置如下图所示:
图片 1

参数说明:user_FieldFun:函数名$mid:系统模型ID$f:字段名$isadd:值为1时是增加信息;值为0时是修改信息$isq:值为0时是后台处理;值为1时是前台处理$value:字段原内容$cs:字段附加参数,字段处理函数处设置的参数内容字段处理函数范例:例子1:自动在标题前面加“[EmpireCMS]”字样后台字段函数设置:user_AddTitle

二、基本设置步骤:

functionuser_AddTitle($mid,$f,$isadd,$isq,$value,$cs){$value=[EmpireCMS].$value;return$value;}

1、编写处理函数;
2、将函数复制到e/class/userfun.php文件内容里;
3、修改字段设置处理函数名称。

例子2:标题内容由writer和befrom字段的组合后台字段函数设置:user_TogTitle标题字段显示HTML代码:input
type=hidden name=title
value=test(说明:因为标题是必填项,所以要给初始值才不会提示内容空)

三、字段处理函数格式:

functionuser_TogTitle($mid,$f,$isadd,$isq,$value,$cs){$value=$_POST[writer].$_POST[befrom];return$value;}

复制代码代码如下:function
user_FieldFun($mid,$f,$isadd,$isq,$value,$cs){
return $value;
}

例子3:上传图片并自动生成缩图后台字段函数设置:user_TranImgAuto##170,120(说明:后台的参数170表示缩图宽度,120为缩图高度)上传图片字段显示HTML代码:input
type=file name=titlepicimgrs
size=45(说明:变量名用“字段名”+imgrs,即跟函数中的“$filetf”变量对应)

参数说明:

functionuser_TranImgAuto($mid,$f,$isadd,$isq,$value,$cs){global$empire,$dbtbpre,$public_r,$emod_r,$class_r,$tranpicturetype,$musername;$filetf=$f.imgrs;//变量名if(!$_FILES[$filetf][name]){return$value;}$classid=(int)$_POST[classid];$id=(int)$_POST[id];$filepass=(int)$_POST[filepass];$filetype=GetFiletype($_FILES[$filetf][name]);$pr=$empire-fetch1(selectqaddtran,qaddtransize,qaddtranimgtypefrom{$dbtbpre}enewspubliclimit1);if(!$pr[qaddtran]){printerror(CloseQTranPic,,1);}if(!strstr($pr[qaddtranimgtype],|.$filetype.|)){printerror(NotQTranFiletype,,1);}if($_FILES[$filetf][size]$pr[qaddtransize]*1024){printerror(TooBigQTranFile,,1);}if(!strstr($tranpicturetype,,.$filetype.,)){printerror(NotQTranFiletype,,1);}$tfr=DoTranFile($_FILES[$filetf][tmp_name],$_FILES[$filetf][name],$_FILES[$filetf][type],$_FILES[$filetf][size],$classid);if($tfr[tran]){$csr=explode(,,$cs);$maxwidth=$csr[0];$maxheight=$csr[1];$yname=$tfr[yname];$name=$tfr[name];include_once(ECMS_PATH.e/class/gd.php);//生成缩图$filer=ResizeImage($yname,$name,$maxwidth,$maxheight,$public_r[spickill]);DelFiletext($yname);if($filer[file]){//写入数据库$type=1;$filetime=date(Y-m-dH:i:s);$filesize=@filesize($filer[file]);$filename=GetFilename(str_replace(ECMS_PATH,,$filer[file]));$adduser=[Member].$musername;$infoid=$isadd==1?0:$id;$empire-query(insertinto{$dbtbpre}enewsfile(filename,filesize,adduser,path,filetime,classid,no,type,id,cjid,fpath)values($filename,$filesize,$adduser,$tfr[filepath],$filetime,$classid,[.$f.].addslashes(RepPostStr($_POST[title])).,$type,$infoid,$filepass,$public_r[fpath]););if($isadd==0){$tbname=$emod_r[$mid][tbname];if(strstr($emod_r[$mid][tbdataf],,.$f.,)){$ir=$empire-fetch1(selectstbfrom{$dbtbpre}ecms_.$tbname.whereid=$id);$ifr=$empire-fetch1(select.$f.from{$dbtbpre}ecms_.$tbname._data_.$ir[stb].whereid=$id);$ifval=$ifr[$f];}else{$ir=$empire-fetch1(select.$f.from{$dbtbpre}ecms_.$tbname.whereid=$id);$ifval=$ir[$f];}if($ifval){DelYQTranFile($classid,$id,$ifval,$f);}}$value=str_replace($tfr[filename],$filename,$tfr[url]);}}else{$value=;}return$value;}

user_FieldFun:函数名
$mid:系统模型ID
$f:字段名
$isadd:值为0时是增加信息;值为1时是修改信息
$isq:值为0时是后台处理;值为1时是前台处理
$value:字段原内容
$cs:字段附加参数,字段处理函数处设置的参数内容

处理函数可以实现很多非常复杂的字段内容存放格式需求,上面只是举了几个简单的例子,更多需要用户去实践。

四、字段处理函数范例:

例子1:自动在标题前面加“[EmpireCMS]”字样
后台字段函数设置:user_AddTitle

复制代码代码如下:function
user_AddTitle($mid,$f,$isadd,$isq,$value,$cs){
$value='[EmpireCMS]’.$value;
return $value;
}

例子2:标题内容由writer和befrom字段的组合
后台字段函数设置:user_TogTitle
标题字段显示HTML代码:
(说明:因为标题是必填项,所以要给初始值才不会提示内容空)

复制代码代码如下:function
user_TogTitle($mid,$f,$isadd,$isq,$value,$cs){
$value=$_POST[‘writer’].$_POST[‘befrom’];
return $value;
}

例子3:上传图片并自动生成缩图
后台字段函数设置:user_TranImgAuto##170,120
(说明:后台的参数170表示缩图宽度,120为缩图高度)
上传图片字段显示HTML代码:
(说明:变量名用“字段名”+imgrs,即跟函数中的“$filetf”变量对应)

复制代码代码如下:function
user_TranImgAuto($mid,$f,$isadd,$isq,$value,$cs){
global
$empire,$dbtbpre,$public_r,$emod_r,$class_r,$tranpicturetype,$musername;
$filetf=$f.’imgrs’;//变量名
if(!$_FILES[$filetf][‘name’])
{
return ”;
}
$classid=(int)$_POST[‘classid’];
$id=(int)$_POST[‘id’];
$filepass=(int)$_POST[‘filepass’];
$filetype=GetFiletype($_FILES[$filetf][‘name’]);
$pr=$empire->fetch1(“select qaddtran,qaddtransize,qaddtranimgtype
from {$dbtbpre}enewspublic limit 1”);
if(!$pr[‘qaddtran’])
{
printerror(“CloseQTranPic”,””,1);
}
if(!strstr($pr[‘qaddtranimgtype’],”|”.$filetype.”|”))
{
printerror(“NotQTranFiletype”,””,1);
}
if($_FILES[$filetf][‘size’]>$pr[‘qaddtransize’]*1024)
{
printerror(“TooBigQTranFile”,””,1);
}
if(!strstr($tranpicturetype,’,’.$filetype.’,’))
{
printerror(“NotQTranFiletype”,””,1);
}
$tfr=DoTranFile($_FILES[$filetf][‘tmp_name’],$_FILES[$filetf][‘name’],$_FILES[$filetf][‘type’],$_FILES[$filetf][‘size’],$classid);
if($tfr[‘tran’])
{
$csr=explode(‘,’,$cs);
$maxwidth=$csr[0];
$maxheight=$csr[1];
$yname=$tfr[‘yname’];
$name=$tfr[‘name’];
include_once(ECMS_PATH.’e/class/gd.php’);
//生成缩图
$filer=ResizeImage($yname,$name,$maxwidth,$maxheight,$public_r[‘spickill’]);
DelFiletext($yname);
if($filer[‘file’])
{
//写入数据库
$type=1;
$filetime=date(“Y-m-d H:i:s”);
$filesize=@filesize($filer[‘file’]);
$filename=GetFilename(str_replace(ECMS_PATH,”,$filer[‘file’]));
$adduser='[Member]’.$musername;
$infoid=$isadd==1?0:$id;
$empire->query(“insert into
{$dbtbpre}enewsfile(filename,filesize,adduser,path,filetime,classid,no,type,id,cjid,fpath)
values(‘$filename’,’$filesize’,’$adduser’,’$tfr[filepath]’,’$filetime’,’$classid’,'[“.$f.”]”.addslashes(RepPostStr($_POST[title])).”‘,’$type’,’$infoid’,’$filepass’,’$public_r[fpath]’);”);
if($isadd==0)
{
$tbname=$emod_r[$mid][‘tbname’];
if(strstr($emod_r[$mid][‘tbdataf’],’,’.$f.’,’))
{
$ir=$empire->fetch1(“select stb from {$dbtbpre}ecms_”.$tbname.”
where id=’$id'”);
$ifr=$empire->fetch1(“select “.$f.” from
{$dbtbpre}ecms_”.$tbname.”_data_”.$ir[stb].” where id=’$id'”);
$ifval=$ifr[$f];
}
else
{
$ir=$empire->fetch1(“select “.$f.” from {$dbtbpre}ecms_”.$tbname.”
where id=’$id'”);
$ifval=$ir[$f];
}
if($ifval)
{
DelYQTranFile($classid,$id,$ifval,$f);
}
}
$value=str_replace($tfr[‘filename’],$filename,$tfr[‘url’]);
}
}
else
{
$value=”;
}
return $value;
}

发表评论

电子邮件地址不会被公开。 必填项已用*标注