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

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

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

参数说明: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;}

例子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;}

例子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;}

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