帝国cms采集插件带云存储 帝国cms二次开发AJAX验证标题是否重复

帝国CMS教程

帝国cms后台发信息最怕点击提交后,提示标题重复又要重新写一遍。现在给大家分享一款实时验证标题的方法,这样就可以避免出现重复的信息。

帝国CMS-AJAX验证标题是否重复方法

1、帝国cms后台 - 管理数据表 - 找到自己使用的数据表 - 修改title字段 - 输入表单使用下面的代码

找到代码

<inputtype=textname=titlevalue="<?=ehtmlspecialchars(stripSlashes($r[title]))?>"size="60">

替换为

<inputtype=textname=titlevalue="<?=ehtmlspecialchars(stripSlashes($r[title]))?>"size="60"onblur="checkTitle()">

在输入表单最下面加入如下代码

<scripttype="text/javascript"src="http://apps.bdimg.com/libs/jquery/1.9.0/jquery.min.js"></script><scripttype="text/javascript">functioncheckTitle(){varclassid=<?=$_GET[classid]?>;varid=<?=$_GET[classid]?>;vartit=document.add.title.value;console.log("我是标题="+tit);console.log("我是classid="+classid);console.log("我是id="+id);$.ajax({url:'ReTitleAjax.php?classid='+classid+'&id='+id+'&title='+tit,dataType:"json",cache:false,error:function(){alert("检测失败,请重试");},success:function(data){if(data==1){alert('重复标题');}if(data==0){//alert('可以添加信息');console.log("可以添加信息");}}});}</script>

接着新建一个php文件,保存在 /e/admin/ReTitleAjax.php ,代码如下

define('EmpireCMSAdmin','1');require("../class/connect.php");require("../class/db_sql.php");require("../class/functions.php");requireLoadLang("pub/fun.php");require("../data/dbcache/class.php");$link=db_connect();$empire=newmysqlquery();$editor=1;//验证用户$lur=is_login();$logininid=$lur['userid'];$loginin=$lur['username'];$loginrnd=$lur['rnd'];$loginlevel=$lur['groupid'];$loginadminstyleid=$lur['adminstyleid'];$classid=(int)$_GET['classid'];$id=(int)$_GET['id'];$title=AddAddsData($_GET['title']);$where='';if($id){$where='andid<>'.$id;}//已审核$num=$empire->gettotal("selectcount(*)astotalfrom{$dbtbpre}ecms_".$class_r[$classid][tbname]."wheretitle='".addslashes($title)."'".$where."limit1");//未审核if(emptyempty($num)){$num=$empire->gettotal("selectcount(*)astotalfrom{$dbtbpre}ecms_".$class_r[$classid][tbname]."_checkwheretitle='".addslashes($title)."'".$where."limit1");}echojson_encode($num);

上面是采用post查询返回json结果的方式来实现查重,我们还可以通过get方式,js函数如下:

<scripttype="text/javascript">functioncheckTitle(){varclassid='<?=$_GET[classid]?>';varid='<?=$_GET[id]?>';vartit=document.add.title.value;varanswerurl='ReTitleAjax.php';$.get(answerurl+"?classid="+classid+'<?=$ecms_hashur['ehref']?>&title='+tit,function(data){if(data){if(data==1){$("#titletips").html("<fontcolor='red'>已经存在此名称,请检查是否已经添加过</font>");}else{$("#titletips").html("<fontcolor='green'>可以添加信息</font>");}returnfalse;}else{$("#titletips").html("<fontcolor='red'>检测失败,请重试</font>");}});}</script>

接着在title字段的input后放一个容器用于存储提示信息,例如<span id="titletips"></span>,还可以通过在出现重复时禁用其他input输入等方式来限制,这里只是给出原理,大家可在此基础上发挥。