文章主要爲大家詳細介紹了ThinkPHP中create()方法自動驗證表單信息,具有一定的參考價值,感興趣的小夥伴們可以參考一下。
自動驗證是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:值不爲空時驗證.
附加規則:
驗證時間(可選):共有1,2,3三種,1:新增數據時候驗證;2:編輯數據時候驗證;3:全部情況下驗證(默認);也可以可以根據業務需要增加其他的驗證時間
下面附上代碼:以註冊爲例
前臺頁面比較簡單,代碼就不貼出來了,下面是前臺註冊界面截圖
控制器代碼:
//註冊
public function register(){
$user = new ModelUserModel();
//兩個邏輯:收集,展示
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);
}