• 设为首页
  • 收藏本站
  • 积分充值
  • VIP赞助
  • 手机版
  • 微博
  • 微信
    微信公众号 添加方式:
    1:搜索微信号(888888
    2:扫描左侧二维码
  • 快捷导航
    福建二哥 门户 查看主题

    帝国CMS功能解密之字段处理函数详解

    发布者: 网神之王 | 发布时间: 2025-7-24 16:27| 查看数: 98| 评论数: 0|帖子模式

    一、前言:
    帝国CMS提供了强大的自定义字段处理函数功能,极大的方便了用户对帝国CMS进行二次开发!
    帝国CMS在增加/修改字段时可以设置“后台增加信息处理函数”、“后台修改信息处理函数”、“前台增加信息处理函数”、“前台修改信息处理函数”,可以分别设置对字段内容处理的函数,对于对字段内容存放格式有特殊要求的模型用得比较多。今天我们来简单讲解下处理函数制作格式。字段处理函数的具体设置位置如下图所示:


    二、基本设置步骤:
    1、编写处理函数;
    2、将函数复制到e/class/userfun.php文件内容里;
    3、修改字段设置处理函数名称。
    三、字段处理函数格式:
     
    代码如下:function user_FieldFun($mid,$f,$isadd,$isq,$value,$cs){
    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?0id;
    $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;
    }
    来源:互联网
    免责声明:如果侵犯了您的权益,请联系站长(1277306191@qq.com),我们会及时删除侵权内容,谢谢合作!

    本帖子中包含更多资源

    您需要 登录 才可以下载或查看,没有账号?立即注册

    ×

    最新评论

    QQ Archiver 手机版 小黑屋 福建二哥 ( 闽ICP备2022004717号|闽公网安备35052402000345号 )

    Powered by Discuz! X3.5 © 2001-2023

    快速回复 返回顶部 返回列表