- 相關(guān)推薦
ThinkPHP中create()方法自動(dòng)驗(yàn)證表單信息
文章主要為大家詳細(xì)介紹了ThinkPHP中create()方法自動(dòng)驗(yàn)證表單信息,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
自動(dòng)驗(yàn)證是ThinkPHP模型層提供的一種數(shù)據(jù)驗(yàn)證方法,可以在使用create創(chuàng)建數(shù)據(jù)對(duì)象的時(shí)候自動(dòng)進(jìn)行數(shù)據(jù)驗(yàn)證。
原理:
create()方法收集表單($_POST)信息并返回,同時(shí)觸發(fā)表單自動(dòng)驗(yàn)證,過(guò)濾非法字段,
在控制器中使用create()方法,(返回值為true/false),會(huì)自動(dòng)觸發(fā)模型類中的$_validate屬性(為父類Model中的方法,在子類Model中重寫(xiě)),在$_validate中自定義驗(yàn)證規(guī)則(驗(yàn)證規(guī)則下面會(huì)詳細(xì)說(shuō)明),當(dāng)create()方法沒(méi)有數(shù)據(jù)即返回值為false時(shí),通過(guò)$xxx對(duì)象->getError();獲取并返回錯(cuò)誤信息!
使用自動(dòng)驗(yàn)證必須按照以下規(guī)則格式定義:
protected $_validate = array(
array(驗(yàn)證字段1,驗(yàn)證規(guī)則,錯(cuò)誤提示,[驗(yàn)證條件,附加規(guī)則,驗(yàn)證時(shí)間]),
array(驗(yàn)證字段2,驗(yàn)證規(guī)則,錯(cuò)誤提示,[驗(yàn)證條件,附加規(guī)則,驗(yàn)證時(shí)間]),
......
);
其中驗(yàn)證字段,驗(yàn)證規(guī)則,錯(cuò)誤提示是必填項(xiàng),驗(yàn)證條件,附加規(guī)則,驗(yàn)證時(shí)間為可選!
驗(yàn)證字段(必填):表單字段。
驗(yàn)證規(guī)則(必填):require 字段必須、email 郵箱、url URL地址、number 數(shù)字,還可以結(jié)合附加規(guī)則使用。
錯(cuò)誤提示(必填):驗(yàn)證失敗時(shí)返回的提示信息。
驗(yàn)證條件(可選):有0,1,2三種,0:_POST中存在的字段驗(yàn)證,默認(rèn);1:驗(yàn)證規(guī)則定義了就必須驗(yàn)證;2:值不為空時(shí)驗(yàn)證.
附加規(guī)則:
驗(yàn)證時(shí)間(可選):共有1,2,3三種,1:新增數(shù)據(jù)時(shí)候驗(yàn)證;2:編輯數(shù)據(jù)時(shí)候驗(yàn)證;3:全部情況下驗(yàn)證(默認(rèn));也可以可以根據(jù)業(yè)務(wù)需要增加其他的驗(yàn)證時(shí)間
下面附上代碼:以注冊(cè)為例
前臺(tái)頁(yè)面比較簡(jiǎn)單,代碼就不貼出來(lái)了,下面是前臺(tái)注冊(cè)界面截圖
控制器代碼:
//注冊(cè)
public function register(){
$user = new \Model\UserModel();
//兩個(gè)邏輯:收集,展示
if (!empty($_POST)) {
//create()方法收集表單($_POST)信息并返回,同時(shí)觸發(fā)表單自動(dòng)驗(yàn)證,過(guò)濾非法字段
$date = $user->create();
//通過(guò)create()方法的返回值$date判斷驗(yàn)證是否成功
if ($date) { //返回實(shí)在數(shù)據(jù)的時(shí)候才進(jìn)行添加
//implode()把數(shù)組變?yōu)樽址?/p>
$date['user_hobby'] = implode(',', $date['user_hobby']);
$info = $user->add($date);
if ($info) {
//跳轉(zhuǎn)首頁(yè)
$this->redirect('Index/index');
}
}else{
//把錯(cuò)誤信息分配到前臺(tái)模板
$error = $user->getError();
$this->assign('error',$error);
}
}
//調(diào)用view視圖
$this->display();
}
模型類代碼:
class UserModel extends Model{
//是否批量處理驗(yàn)證,批量獲取全部的錯(cuò)誤驗(yàn)證信息
protected $patchValidate = true; //默認(rèn)為false
//自動(dòng)驗(yàn)證定義
protected $_validate = array(
//array(字段,驗(yàn)證規(guī)則,錯(cuò)誤提示,驗(yàn)證條件,附加規(guī)則,驗(yàn)證時(shí)間)
//①用戶名驗(yàn)證,不能為空
array('username','require','用戶名不能為空'),
array('username','','該用戶名已經(jīng)被占用','0','unique'),
//②密碼驗(yàn)證,不為空
array('password','require','密碼不能為空'),
//③驗(yàn)證確認(rèn)密碼,必須填寫(xiě),與密碼保持一致
array('password2','require','確認(rèn)密碼必須填寫(xiě)'),
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)證,必須選一個(gè)
array('user_xueli','2,5','學(xué)位必須選擇一個(gè)',0,'between'),
//⑦愛(ài)好驗(yàn)證,必須選擇二個(gè)以上
//因?yàn)閻?ài)好返回的是數(shù)組,附加規(guī)則中沒(méi)有可以直接用的規(guī)則,所以需自定義方法,用callback方法驗(yàn)證
array('user_hobby','check_hobby','愛(ài)好必須選兩項(xiàng)或以上',1,'callback'),
);
//定義方法進(jìn)行愛(ài)好驗(yàn)證
//參數(shù)$arg代表被驗(yàn)證的表單信息
function check_hobby($arg)
{
//判斷數(shù)組長(zhǎng)度是否大于2
if (count($arg)<2) {
return false; //會(huì)自動(dòng)輸出驗(yàn)證錯(cuò)誤信息
}
return true;
}
}
把驗(yàn)證的錯(cuò)誤信息在模板中給展示出來(lái)(部分代碼)
<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>
【ThinkPHP中create()方法自動(dòng)驗(yàn)證表單信息】相關(guān)文章:
ThinkPHP表單自動(dòng)提交驗(yàn)證實(shí)例教程10-08
PHP 表單驗(yàn)證方法11-01
php中tp驗(yàn)證表單與自動(dòng)填充函數(shù)代碼07-16
常用表單驗(yàn)證的js方法11-12
兩種實(shí)現(xiàn)表單驗(yàn)證的javascript方法09-19
PHP中Yii框架之表單驗(yàn)證規(guī)則06-08
使用php自動(dòng)提交表單的方法11-16