婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 網(wǎng)站建設(shè) > 建站知識 > 織夢實現(xiàn)自定義表單提交信息必填項 數(shù)據(jù)過濾

織夢實現(xiàn)自定義表單提交信息必填項 數(shù)據(jù)過濾

POST TIME:2020-04-12 22:48

織夢自定義表單

1.前臺提交數(shù)據(jù)過濾

前臺數(shù)據(jù)過濾主要針對普通用戶,在HTML層面,通過Js方式,對提交的數(shù)據(jù)進行校驗。如判斷表單是否為空、郵箱是否正確等。比如使用下面的Js代碼來驗證提交的內(nèi)容是否為空:

<script type="text/javascript"> function check(){ var fankui=document.getElementById('fankui'); var names=document.getElementById('names'); if(fankui.value.length==0){ alert("反饋內(nèi)容不能為空"); fankui.value=""; fankui.focus(); return false; } if(names.value.length==0){ alert("姓名不能為空"); names.value=""; names.focus(); return false; } } </script>

這是很簡單的驗證辦法,一般情況下使用這個驗證就足夠了,但修改后依然會被垃圾信息騷擾,而上面的JS也僅僅是判斷是否為空,表單也非常簡單,隨便填寫幾個數(shù)值就能夠通過。

所以建議采用一些別的成熟的表單驗證插件,如一款jquery表單驗證插件Validform,可以實現(xiàn)更加強大的驗證功能等,如是否提交的郵箱、手機等信息。

當(dāng)然,這個只是前臺界面的數(shù)據(jù)驗證,只能防范一些不懂網(wǎng)站制作的用戶,稍微懂些網(wǎng)站知識的用戶,就可以繞開前臺直接向系統(tǒng)提交數(shù)據(jù),這就需要在提交的PHP文件中進行相應(yīng)的數(shù)據(jù)校驗了。

2.PHP提交數(shù)據(jù)過濾

織夢DedeCMS的自定義表單提交PHP文件是plus下的diy.php文件,所以對提交數(shù)據(jù)的校驗也在這個文件中進行。比如校驗用戶提交的某個字段是否是手機號、郵箱等。這種校驗的方法是利用正則表達式的方式,檢測手機號碼和郵箱,修改plus下的diy.php,再提交入庫的代碼前插入下面代碼:

//判斷手機號碼是否正確 if(!eregi("^((13[0-9])|147|(15[0-35-9])|180|182|(18[5-9]))[0-9]{8}$",$telphone)) { showMsg('手機號碼不對,請正確填寫', '-1'); exit(); } //驗證郵箱 if (!eregi("^[_.0-9a-z-]+@([0-9a-z][0-9a-z-]+.)+[a-z]{2,3}$",$email)) { showMsg('請您填寫正確的E-Mail 地址!', '-1'); exit(); }

其中的 $telphone和$email就是提交的手機號碼和郵箱值名,如果不是我設(shè)定的可以自行修改。所以這里使用的正則表達式是否正確就非常重要了,不正確的正則表達式,會造成垃圾信息提交或者正常的信息無法提交等后果

3.PHP限制用戶提交次數(shù)

解決以上兩個問題之后,還有一個問題,就是某些用戶有意或者無意的提交了多次表單,這也會給信息收集工作帶來巨大的壓力,所以我們也要努力地降低這個方面的工作量。我們可以采用驗證Cookies方法,達到織夢DedeCMS自定義表單限制IP24小時只能發(fā)布一次功能。

實現(xiàn)方法是,打開plus下diy.php文件找到以下代碼:

if(!is_array($diyform)) { showmsg('自定義表單不存在', '-1'); exit(); }
再其下添加下面的代碼:
if(isset($_COOKIE['VOTE_MEMBER_IP'])) { if($_COOKIE['VOTE_MEMBER_IP'] == $_SERVER['REMOTE_ADDR']) { ShowMsg('您已經(jīng)填寫過表單啦','-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,'/'); }
當(dāng)然,經(jīng)過以上的操作,織夢DedeCMS的自定義表單并不是就完全的安全了,別人還可以清空Cookies的方式繼續(xù)重復(fù)提交,不過這些就不需要考慮那么多了,畢竟道高一尺魔高一丈,不可能百分百完美的。



收縮
  • 微信客服
  • 微信二維碼
  • 電話咨詢

  • 400-1100-266
主站蜘蛛池模板: 桐城市| 城固县| 宁都县| 江油市| 崇礼县| 禹城市| 洞口县| 鹰潭市| 衡东县| 兴国县| 乐陵市| 会理县| 阳新县| 高碑店市| 邵东县| 眉山市| 长春市| 辽源市| 吉林省| 云龙县| 河北省| 泗洪县| 永嘉县| 连城县| 揭阳市| 洪江市| 海原县| 合阳县| 牡丹江市| 正安县| 集安市| 蒙城县| 伽师县| 桐梓县| 麟游县| 祁连县| 武定县| 湖北省| 山东省| 怀来县| 兴文县|