自動驗證是ThinkPHP模型層提供的一種數據驗證方法,可以在使用create創建數據對象的時候自動進行數據驗證。
原理:
create()方法收集表單($_POST)信息并返回,同時觸發表單自動驗證,過濾非法字段,
在控制器中使用create()方法,(返回值為true/false),會自動觸發模型類中的$_validate屬性(為父類Model中的方法,在子類Model中重寫),在$_validate中自定義驗證規則(驗證規則下面會詳細說明),當create()方法沒有數據即返回值為false時,通過$xxx對象->getError();獲取并返回錯誤信息!
使用自動驗證必須按照以下規則格式定義:
protected $_validate = array( array(驗證字段1,驗證規則,錯誤提示,[驗證條件,附加規則,驗證時間]), array(驗證字段2,驗證規則,錯誤提示,[驗證條件,附加規則,驗證時間]), ...... );
其中驗證字段,驗證規則,錯誤提示是必填項,驗證條件,附加規則,驗證時間為可選!
驗證字段(必填):表單字段。
驗證規則(必填):require 字段必須、email 郵箱、url URL地址、number 數字,還可以結合附加規則使用。
錯誤提示(必填):驗證失敗時返回的提示信息。
驗證條件(可選):有0,1,2三種,0:_POST中存在的字段驗證,默認;1:驗證規則定義了就必須驗證;2:值不為空時驗證.
附加規則:
regex | 正則驗證,定義的驗證規則是一個正則表達式(默認) |
function | 函數驗證,定義的驗證規則是一個函數名 |
callback | 方法驗證,定義的驗證規則是當前模型類的一個方法 |
confirm | 驗證表單中的兩個字段是否相同,定義的驗證規則是一個字段名 |
equal | 驗證是否等于某個值,該值由前面的驗證規則定義 |
notequal | 驗證是否不等于某個值,該值由前面的驗證規則定義(3.1.2版本新增) |
in | 驗證是否在某個范圍內,定義的驗證規則可以是一個數組或者逗號分割的字符串 |
notin | 驗證是否不在某個范圍內,定義的驗證規則可以是一個數組或者逗號分割的字符串(3.1.2版本新增) |
length | 驗證長度,定義的驗證規則可以是一個數字(表示固定長度)或者數字范圍(例如3,12 表示長度從3到12的范圍) |
between | 驗證范圍,定義的驗證規則表示范圍,可以使用字符串或者數組,例如1,31或者array(1,31) |
notbetween | 驗證不在某個范圍,定義的驗證規則表示范圍,可以使用字符串或者數組(3.1.2版本新增) |
expire | 驗證是否在有效期,定義的驗證規則表示時間范圍,可以到時間,例如可以使用 2012-1-15,2013-1-15 表示當前提交有效期在2012-1-15到2013-1-15之間,也可以使用時間戳定義 |
ip_allow | 驗證IP是否允許,定義的驗證規則表示允許的IP地址列表,用逗號分隔,例如201.12.2.5,201.12.2.6 |
ip_deny | 驗證IP是否禁止,定義的驗證規則表示禁止的ip地址列表,用逗號分隔,例如201.12.2.5,201.12.2.6 |
unique | 驗證是否唯一,系統會根據字段目前的值查詢數據庫來判斷是否存在相同的值,當表單數據中包含主鍵字段時unique不可用于判斷主鍵字段本身 |
驗證時間(可選):共有1,2,3三種,1:新增數據時候驗證;2:編輯數據時候驗證;3:全部情況下驗證(默認);也可以可以根據業務需要增加其他的驗證時間
下面附上代碼:以注冊為例
前臺頁面比較簡單,代碼就不貼出來了,下面是前臺注冊界面截圖
控制器代碼:
//注冊 public function register(){ $user = new \Model\UserModel(); //兩個邏輯:收集,展示 if (!empty($_POST)) { //create()方法收集表單($_POST)信息并返回,同時觸發表單自動驗證,過濾非法字段 $date = $user->create(); //通過create()方法的返回值$date判斷驗證是否成功 if ($date) { //返回實在數據的時候才進行添加 //implode()把數組變為字符串 $date['user_hobby'] = implode(',', $date['user_hobby']); $info = $user->add($date); if ($info) { //跳轉首頁 $this->redirect('Index/index'); } }else{ //把錯誤信息分配到前臺模板 $error = $user->getError(); $this->assign('error',$error); } } //調用view視圖 $this->display(); }
【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。