自動驗(yàn)證是ThinkPHP模型層提供的一種數(shù)據(jù)驗(yàn)證方法,可以在使用create創(chuàng)建數(shù)據(jù)對象的時候自動進(jìn)行數(shù)據(jù)驗(yàn)證。
原理:
create()方法收集表單($_POST)信息并返回,同時觸發(fā)表單自動驗(yàn)證,過濾非法字段,
在控制器中使用create()方法,(返回值為true/false),會自動觸發(fā)模型類中的$_validate屬性(為父類Model中的方法,在子類Model中重寫),在$_validate中自定義驗(yàn)證規(guī)則(驗(yàn)證規(guī)則下面會詳細(xì)說明),當(dāng)create()方法沒有數(shù)據(jù)即返回值為false時,通過$xxx對象->getError();獲取并返回錯誤信息!
使用自動驗(yàn)證必須按照以下規(guī)則格式定義:
protected $_validate = array( array(驗(yàn)證字段1,驗(yàn)證規(guī)則,錯誤提示,[驗(yàn)證條件,附加規(guī)則,驗(yàn)證時間]), array(驗(yàn)證字段2,驗(yàn)證規(guī)則,錯誤提示,[驗(yàn)證條件,附加規(guī)則,驗(yàn)證時間]), ...... );
其中驗(yàn)證字段,驗(yàn)證規(guī)則,錯誤提示是必填項(xiàng),驗(yàn)證條件,附加規(guī)則,驗(yàn)證時間為可選!
驗(yàn)證字段(必填):表單字段。
驗(yàn)證規(guī)則(必填):require 字段必須、email 郵箱、url URL地址、number 數(shù)字,還可以結(jié)合附加規(guī)則使用。
錯誤提示(必填):驗(yàn)證失敗時返回的提示信息。
驗(yàn)證條件(可選):有0,1,2三種,0:_POST中存在的字段驗(yàn)證,默認(rèn);1:驗(yàn)證規(guī)則定義了就必須驗(yàn)證;2:值不為空時驗(yàn)證.
附加規(guī)則:
驗(yàn)證時間(可選):共有1,2,3三種,1:新增數(shù)據(jù)時候驗(yàn)證;2:編輯數(shù)據(jù)時候驗(yàn)證;3:全部情況下驗(yàn)證(默認(rèn));也可以可以根據(jù)業(yè)務(wù)需要增加其他的驗(yàn)證時間
下面附上代碼:以注冊為例
前臺頁面比較簡單,代碼就不貼出來了,下面是前臺注冊界面截圖
控制器代碼:
//注冊 public function register(){ $user = new ModelUserModel(); //兩個邏輯:收集,展示 if (!empty($_POST)) { //create()方法收集表單($_POST)信息并返回,同時觸發(fā)表單自動驗(yàn)證,過濾非法字段 $date = $user->create(); //通過create()方法的返回值$date判斷驗(yàn)證是否成功 if ($date) { //返回實(shí)在數(shù)據(jù)的時候才進(jìn)行添加 //implode()把數(shù)組變?yōu)樽址? $date['user_hobby'] = implode(',', $date['user_hobby']); $info = $user->add($date); if ($info) { //跳轉(zhuǎn)首頁 $this->redirect('Index/index'); } }else{ //把錯誤信息分配到前臺模板 $error = $user->getError(); $this->assign('error',$error); } } //調(diào)用view視圖 $this->display(); }
模型類代碼:
class UserModel extends Model{ //是否批量處理驗(yàn)證,批量獲取全部的錯誤驗(yàn)證信息 protected $patchValidate = true; //默認(rèn)為false //自動驗(yàn)證定義 protected $_validate = array( //array(字段,驗(yàn)證規(guī)則,錯誤提示,驗(yàn)證條件,附加規(guī)則,驗(yàn)證時間) //①用戶名驗(yàn)證,不能為空 array('username','require','用戶名不能為空'), array('username','','該用戶名已經(jīng)被占用','0','unique'), //②密碼驗(yàn)證,不為空 array('password','require','密碼不能為空'), //③驗(yàn)證確認(rèn)密碼,必須填寫,與密碼保持一致 array('password2','require','確認(rèn)密碼必須填寫'), array('password2','password','兩次密碼保持一致',0,'confirm'), //④郵箱驗(yàn)證 array('user_email','email','郵箱格式不正確',2), //⑤qq驗(yàn)證,數(shù)字組成,5-12位 array('user_qq','number','qq必須是數(shù)字'), array('user_qq','5,12','位數(shù)在5-12位之間',0,'length'), //⑥學(xué)歷驗(yàn)證,必須選一個 array('user_xueli','2,5','學(xué)位必須選擇一個',0,'between'), //⑦愛好驗(yàn)證,必須選擇二個以上 //因?yàn)閻酆梅祷氐氖菙?shù)組,附加規(guī)則中沒有可以直接用的規(guī)則,所以需自定義方法,用callback方法驗(yàn)證 array('user_hobby','check_hobby','愛好必須選兩項(xiàng)或以上',1,'callback'), ); //定義方法進(jìn)行愛好驗(yàn)證 //參數(shù)$arg代表被驗(yàn)證的表單信息 function check_hobby($arg) { //判斷數(shù)組長度是否大于2 if (count($arg)<2) { return false; //會自動輸出驗(yàn)證錯誤信息 } return true; } }
把驗(yàn)證的錯誤信息在模板中給展示出來(部分代碼)
<td style="width:13%; text-align: right;"> <label for="User_username" class="required">用戶名 <span>*</span></label> </td> <td style="width:87%;"> <input class="inputBg" size="25" name="username" id="User_username" type="text" value="" /> <span style="color:red;"><{$error.username|default:""}></span> </td>
結(jié)果:
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持綠夏網(wǎng)。