新聞中心
本篇文章為大家展示了怎么在thinkPHP中實(shí)現(xiàn)一個(gè)表單自動(dòng)驗(yàn)證功能,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過(guò)這篇文章的詳細(xì)介紹希望你能有所收獲。
thinkphp 在Model基類為我們定義了自動(dòng)驗(yàn)證的函數(shù)和正則表達(dá)式,我們只需要在對(duì)應(yīng)的數(shù)據(jù)庫(kù)表的模型類下建立$_validate屬性就可以了。
1、我們找到Model基類,可以看到 protected $_validate = array(); // 自動(dòng)驗(yàn)證定,它是數(shù)組類型的,下面在對(duì)應(yīng)數(shù)據(jù)模型文件定義它;
2、
復(fù)制代碼 代碼如下:
public function CheckVerify($verify) {
if (md5($verify) != Session::get('verify')) return false;
return true;
}
//自動(dòng)驗(yàn)證
復(fù)制代碼 代碼如下:
protected $_validate = array(
array("title", "require", "標(biāo)題必須!"),
array('categoryId', 'require', "類別必須!"),
array('content', 'require', "內(nèi)容必須!"),
array('verify', 'require','驗(yàn)證碼必須!'),
array('verify', 'CheckVerify', '驗(yàn)證碼錯(cuò)誤!', 0, 'callback')
);
3、格式說(shuō)明:array(驗(yàn)證字段,驗(yàn)證規(guī)則,錯(cuò)誤提示,驗(yàn)證條件,附加規(guī)則,驗(yàn)證時(shí)間),
4、參數(shù)解釋:
驗(yàn)證字段:需要驗(yàn)證的表單字段名稱,這個(gè)字段不一定是數(shù)據(jù)庫(kù)字段,也可以是表單的一些輔助字段,例如確認(rèn)密碼和驗(yàn)證碼等等。
驗(yàn)證規(guī)則: 要進(jìn)行驗(yàn)證的規(guī)則,需要結(jié)合附加規(guī)則(必須),官方已經(jīng)包含的規(guī)則如下(自己同時(shí)也可以加):
復(fù)制代碼 代碼如下:
$validate = array(
'require'=> '/.+/',
'email' => '/^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/',
'url' => '/^http:\/\/[A-Za-z0-9]+\.[A-Za-z0-9]+[\/=\?%\-&_~`@[\]\':+!]*([^<>\"\"])*$/',
'currency' => '/^\d+(\.\d+)?$/',
'number' => '/^\d+$/',
'zip' => '/^[1-9]\d{5}$/',
'integer' => '/^[-\+]?\d+$/',
'double' => '/^[-\+]?\d+(\.\d+)?$/',
'english' => '/^[A-Za-z]+$/',
);
提示信息: 用于驗(yàn)證失敗后的提示信息定義(必須)、
驗(yàn)證條件:(可選)
驗(yàn)證條件的規(guī)則有三條:
Model::EXISTS_TO_VAILIDATE 或者0 存在字段就驗(yàn)證 (默認(rèn))
Model::MUST_TO_VALIDATE 或者1 必須驗(yàn)證
Model::VALUE_TO_VAILIDATE或者2 值不為空的時(shí)候驗(yàn)證
附加規(guī)則:
regex 正則驗(yàn)證,說(shuō)明前面的那個(gè)驗(yàn)證規(guī)則是一個(gè)正則表達(dá)式;
function 使用函數(shù)驗(yàn)證,說(shuō)明前面的那個(gè)驗(yàn)證是個(gè)函數(shù)名;
callback 使用方法驗(yàn)證,說(shuō)明驗(yàn)證規(guī)則是一個(gè)Model類的方法;
confirm 驗(yàn)證表單中的兩個(gè)字段是否相等,驗(yàn)證規(guī)則是一個(gè)字段名;
equal 驗(yàn)證是否等于某個(gè)值,這個(gè)值是有前面的驗(yàn)證規(guī)則定義的;
in 驗(yàn)證是否在某個(gè)范圍之內(nèi),前面定義的是一個(gè)數(shù)組;
unique 驗(yàn)證是否,系統(tǒng)會(huì)根據(jù)字段目前的值查詢數(shù)據(jù)庫(kù)來(lái)判斷時(shí)候存在相同的值;
同時(shí),系統(tǒng)還內(nèi)置了一些常用的正則驗(yàn)證規(guī)則,可以這節(jié)使用,包括:require字段必須,email 郵箱;
currency 貨幣,number 數(shù)字,這些驗(yàn)證規(guī)則可以直接使用;
驗(yàn)證時(shí)間:(可選)
01.Model:: MODEL_INSERT 或者1新增數(shù)據(jù)時(shí)候驗(yàn)證
02.Model:: MODEL_UPDATE 或者2編輯數(shù)據(jù)時(shí)候驗(yàn)證
03.Model:: MODEL_BOTH 或者3 全部情況下驗(yàn)證(默認(rèn))
5、官方示例:
復(fù)制代碼 代碼如下:
protected $_validate = array(
array('verify','require','驗(yàn)證碼必須!'), //默認(rèn)情況下用正則進(jìn)行驗(yàn)證
array(name,'','帳號(hào)名稱已經(jīng)存在!',0,'unique',1), // 在新增的時(shí)候驗(yàn)證name字段是否
array('value',array(1,2,3),'值的范圍不正確!',2,'in'), // 當(dāng)值不為空的時(shí)候判斷是否在一個(gè)范圍內(nèi)
array('repassword','password','確認(rèn)密碼不正確',0,'confirm'), // 驗(yàn)證確認(rèn)密碼是否和密碼一致
array('password','checkPwd','密碼格式不正確',0,'function')// 自定義函數(shù)驗(yàn)證密碼格式
);
上述內(nèi)容就是怎么在thinkPHP中實(shí)現(xiàn)一個(gè)表單自動(dòng)驗(yàn)證功能,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
分享文章:怎么在thinkPHP中實(shí)現(xiàn)一個(gè)表單自動(dòng)驗(yàn)證功能-創(chuàng)新互聯(lián)
文章源于:http://www.dlmjj.cn/article/dhgdch.html