最新公告
  • 欢迎您光临牛气网,本站秉承“用心服务,做好服务”致力为站长提供优质的售后服务!立即加入我们
  • 织梦自定义表单加入号码邮箱格式验证,过滤垃圾信息

    织梦DedeCMS的自定义表单如何进行号码邮箱等数据校验,并且过滤一些无聊或者别有用心的用户提交的垃圾信息。提高织梦系统的安全性,防止恶意提交的方式

    步骤一:前端js判断号码邮箱等格式验证

    <form action="/plus/diy.php" enctype="multipart/form-data" method="post" name="gbook" onsubmit="return saveIt();">
    <input type="hidden" name="action" value="post" />
    <input type="hidden" name="diyid" value="1" />
    <input type="hidden" name="do" value="2" />
    <input name="name" id="name" type="text" placeholder=" 姓名:" />
    <input name="tel" id="tel" type="text" placeholder=" 电话:" />
    <input name="mail" id="mail" type="text" placeholder="邮箱:" />
    <textarea name="nr" id="nr"></textarea>
    <input type="submit" name="submit" value="提交" />
    <input type="reset" name="reset" value="重置" />
    <input type="hidden" name="dede_fields" value="name,text;tel,text;mail,text;nr,multitext" />
    <input type="hidden" name="dede_fieldshash" value="657cee014gga977ca8ef4965fjh7469a" />
    </form>

    <!–表单提交电话邮箱等数据验证–>

    <script language="JavaScript" type="text/javascript">
    function saveIt()
    {
    with(gbook)
    {
    if (name.value=="")
    {
    alert('请填写姓名!');
    name.focus();
    return false;
    }
    if (tel.value=="")
    {
    alert('请填写手机号!');
    tel.focus();
    return false;
    }
    var myreg = /^((1[0-9][0-9]{1})+\\d{8})$/;
    if(!myreg.test($("#tel").val()))
    {
    alert('请填写正确的手机号码!');
    tel.focus();
    return false;
    }

    if (mail.value.length!=0)
    {
    if(
    mail.value.charAt(0)=="."||
    mail.value.charAt(0)=="@"||
    mail.value.indexOf('@')==-1||
    mail.value.indexOf('.')==-1||
    mail.value.indexOf("@")==mail.value.length-1||
    mail.value.lastIndexOf(".")==mail.value.length-1
    )
    {
    alert('邮箱地址格式不正确!');
    mail.focus();
    return false;
    }
    }
    if (nr.value.length>150)
    {
    alert('留言内容太多!');
    nr.focus();
    return false;
    }
    }
    }
    </script>

    第一步这个只是前端网页的数据验证,只能防范一些不懂网站制作的用户,稍微懂些程序的用户,就可以绕开前台直接向系统提交数据,这就需要在提交的地址diy.php文件里进行相应的数据校验了。比如校验用户提交的某个字段是否是手机号、邮箱等。我们可以采用PHP正则表达式来进行验证,修改方法如下:

    打开plus/diy.php文件找到以下代码:

    if(!is_array($diyform))

    {

    showmsg('自定义表单不存在', '-1');

    exit();

    }

    在下面添加一下代码:

    //判断手机号码是否正确

    if(!eregi("^((13[0-9])|147|(15[0-35-9])|180|182|(18[5-9]))[0-9]{8}$",$tel))

    { showMsg('手机号码不对,请正确填写', '-1');

    exit();

    }

    //验证邮箱

    if (!eregi("^[_\\.0-9a-z-]+@([0-9a-z][0-9a-z-]+\\.)+[a-z]{2,3}$",$mail))

    {showMsg('请您填写正确的E-Mail地址!', '-1');

    exit();

    }

    解决以上问题之后,还有一个问题,就是某些用户有意或者无意的提交了多次表单,这也会给信息收集工作带来巨大的压力,所以我们也要努力地降低这个方面的工作量。我们可以采用验证Cookies方法,达到织梦DedeCMS自定义表单限制IP24小时只能发布一次功能。

    步骤二:紧接着第二步添加代码的下面加入以下代码

    //检测游客是否已经提交过表单
    if(isset($_COOKIE['VOTE_MEMBER_IP']))
    {
    if($_COOKIE['VOTE_MEMBER_IP'] == $_SERVER['REMOTE_ADDR'])
    {
    ShowMsg('您已经填写过表单啦','-1');
    exit();
    } else {
    setcookie('VOTE_MEMBER_IP',$_SERVER['REMOTE_ADDR'],time()*$row['spec']*3600,'/');
    }
    } else {
    setcookie('VOTE_MEMBER_IP',$_SERVER['REMOTE_ADDR'],time()*$row['spec']*3600,'/');

    }

    当然,经过以上的操作,织梦DedeCMS的自定义表单并不是就完全的安全了,别人还可以清空Cookies或者使用VPN之类的软件等进行继续重复提交,不过这些就不需要考虑那么多了,毕竟道高一尺魔高一丈,不可能百分百完美的。

    1、本站所有资源皆来源于网络和用户自行上传,因此不包括售后和技术,敬请谅解!
    2、本站不保证所提供的源码的准确性、安全性和功能完善性,资源仅用于学习用!
    3、您下载的资源,请务必在24小时内删除,资源仅提供本地测试,请勿商用或者非法用途都与本站无关,一切后果自负!
    4、如发现资源下载不了,或者侵权请及时联系客服或者邮箱admin#niuqi.net,#改为@!
    牛气网 » 织梦自定义表单加入号码邮箱格式验证,过滤垃圾信息

    发表评论

    售后服务:

    • 售后服务范围 1、商业模板使用范围内问题免费咨询
      2、源码安装、模板安装(一般 ¥50-300)服务答疑仅限SVIP用户
      3、单价超过200元的模板免费一次安装,需提供服务器信息。
      付费增值服务 1、提供dedecms模板、WordPress主题、discuz模板优化等服务请详询在线客服
      2、承接 WordPress、DedeCMS、Discuz 等系统建站、仿站、开发、定制等服务
      3、服务器环境配置(一般 ¥50-300)
      4、网站中毒处理(需额外付费,500元/次/质保三个月)
      售后服务时间 周一至周日(法定节假日除外) 9:00-23:00
      免责声明 本站所提供的模板(主题/插件)等资源仅供学习交流,若使用商业用途,请购买正版授权,否则产生的一切后果将由下载用户自行承担,有部分资源为网上收集或仿制而来,若模板侵犯了您的合法权益,请来信通知我们(Email: admin@niuqi.net),我们会及时删除,给您带来的不便,我们深表歉意!

    Hi, 如果你对这款模板有疑问,可以跟我联系哦!

    联系作者

    发表评论

    售后服务:

    • 售后服务范围 1、商业模板使用范围内问题免费咨询
      2、源码安装、模板安装(一般 ¥50-300)服务答疑仅限SVIP用户
      3、单价超过200元的模板免费一次安装,需提供服务器信息。
      付费增值服务 1、提供dedecms模板、WordPress主题、discuz模板优化等服务请详询在线客服
      2、承接 WordPress、DedeCMS、Discuz 等系统建站、仿站、开发、定制等服务
      3、服务器环境配置(一般 ¥50-300)
      4、网站中毒处理(需额外付费,500元/次/质保三个月)
      售后服务时间 周一至周日(法定节假日除外) 9:00-23:00
      免责声明 本站所提供的模板(主题/插件)等资源仅供学习交流,若使用商业用途,请购买正版授权,否则产生的一切后果将由下载用户自行承担,有部分资源为网上收集或仿制而来,若模板侵犯了您的合法权益,请来信通知我们(Email: admin@niuqi.net),我们会及时删除,给您带来的不便,我们深表歉意!

    Hi, 如果你对这款模板有疑问,可以跟我联系哦!

    联系作者
    • 60会员总数(位)
    • 3228资源总数(个)
    • 1990本月发布(个)
    • 81 今日发布(个)
    • 372已陪伴您(天)

    牛气网NIUQI.NET站长源码平台

    开通SVIP会员 了解详情
    升级SVIP尊享更多特权立即升级