帝国cms字段处理函数

帝国cms字段处理函数

浏览次数:
作者: 墨鱼
信息来源: 本站原创
更新日期: 2016-07-26 15:35:50
文章简介

前言:增加/修改字段时可以设置 后台增加信息处理函数 后台修改信息处理函数 前台增加信息处理函数 前台修改信息处理函数 ,可以分别设置对字段内容处理的函数,对于对字段内容存

  • 正文开始
  • 相关阅读
  • 推荐作品

前言:
增加/修改字段时可以设置 后台增加信息处理函数 后台修改信息处理函数 前台增加信息处理函数 前台修改信息处理函数 ,可以分别设置对字段内容处理的函数,对于对字段内容存放格式有特殊要求的模型用得比较多。今天我们再简单讲解下处理函数制作格式。
帝国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:值为1时是增加信息;值为0时是修改信息
$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代码:<input type="hidden" name="title" value="test">
(说明:因为标题是必填项,所以要给初始值才不会提示内容空)

function user_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">
(说明:变量名用&ldquo;字段名&rdquo;+imgrs,即跟函数中的&ldquo;$filetf&rdquo;变量对应)

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 $value;        }        $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;}

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

解决帝国cms官方结合项插件静态页classid为空导致无法找到页面问题
« 上一篇 2016年07月26日
帝国cms 增加底部访问数统计图片(计数器)
下一篇 » 2016年08月02日
  • 微软bing IndexNow的推送和管理-帝国CMS插件
    23阅读0条评论0个赞
    微软Bing IndexNow推送管理插件,专为帝国CMS打造。本教程指导您如何高效利用该插件,实现网站内容快速被Bing搜索引擎收录。通过简单配置,即可自动化推送新发布或更新的页面至Bing,加速索引过程,提升网站SEO效果。轻松管理推送历史,监控索引状态,确保网站内容及时展现给目标用户。优化网站可见性,从掌握Bing IndexNow推送管理开始。
  • 帝国CMS8.0测试版搜索结果页只显示第1页的解决方法
    50阅读0条评论0个赞
    对于刚安装帝国CMS8.0测试版尝鲜的小伙伴们可能发现,使用高级搜索的时候结果页只显示第1页,虽然帝国CMS开发者说正式版会解决此问题,但是临时使用还是要先解决这个问题的。所以今天墨鱼就说下临时的解决方法。
  • 【优化分享】帝国CMS大数据量筛选性能瓶颈突破实践
    243阅读0条评论5个赞
    突破帝国CMS大数据筛选性能瓶颈实战教程:掌握高效技巧,轻松应对海量数据处理挑战。本教程详解性能优化策略,助力快速筛选,提升系统响应速度。无论你是开发者还是管理员,都能从中获益,实现数据筛选效率飞跃,让帝国CMS在大数据环境下依然流畅运行。立即学习,解锁大数据处理新技能!
  • 帝国CMS统计多个数据表今日更新总数代码
    166阅读0条评论4个赞
    帝国CMS统计多表今日更新总数代码教程:通过SQL查询结合帝国CMS函数,汇总多个数据表中今日更新的记录总数。步骤包括编写SQL联合查询语句,利用`DATE()`函数筛选今日数据,结合帝国CMS的数据库操作函数执行查询,并输出结果。此教程教你高效获取多表今日更新概况,优化管理效率。
  • bat批处理,要求根据文件列表里面的文件名称,删除目录里不在文件列表里的文件,并生成一个删除的文件列表
    90阅读0条评论3个赞
    使用BAT批处理脚本,可根据文件列表清理目录中多余文件,并生成删除文件记录。步骤:1.创建包含需保留文件名的列表文件。2.编写BAT脚本,遍历目录文件,对比列表,删除不在列表中的文件,并记录删除的文件名至新列表。3.运行脚本,完成清理及记录。此教程旨在简化文件管理,确保目录仅含必需文件,同时提供删除文件清单以备查。

如本文对您有帮助,就请墨鱼抽根烟吧!