ThinkPHP中create()方法自動(dòng)驗(yàn)證實(shí)例
自動(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中重寫),在$_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ī)則:
| regex | 正則驗(yàn)證,定義的驗(yàn)證規(guī)則是一個(gè)正則表達(dá)式(默認(rèn)) |
| function | 函數(shù)驗(yàn)證,定義的驗(yàn)證規(guī)則是一個(gè)函數(shù)名 |
| callback | 方法驗(yàn)證,定義的驗(yàn)證規(guī)則是當(dāng)前模型類的一個(gè)方法 |
| confirm | 驗(yàn)證表單中的兩個(gè)字段是否相同,定義的驗(yàn)證規(guī)則是一個(gè)字段名 |
| equal | 驗(yàn)證是否等于某個(gè)值,該值由前面的驗(yàn)證規(guī)則定義 |
| notequal | 驗(yàn)證是否不等于某個(gè)值,該值由前面的驗(yàn)證規(guī)則定義(3.1.2版本新增) |
| in | 驗(yàn)證是否在某個(gè)范圍內(nèi),定義的驗(yàn)證規(guī)則可以是一個(gè)數(shù)組或者逗號(hào)分割的字符串 |
| notin | 驗(yàn)證是否不在某個(gè)范圍內(nèi),定義的驗(yàn)證規(guī)則可以是一個(gè)數(shù)組或者逗號(hào)分割的字符串(3.1.2版本新增) |
| length | 驗(yàn)證長(zhǎng)度,定義的驗(yàn)證規(guī)則可以是一個(gè)數(shù)字(表示固定長(zhǎng)度)或者數(shù)字范圍(例如3,12 表示長(zhǎng)度從3到12的范圍) |
| between | 驗(yàn)證范圍,定義的驗(yàn)證規(guī)則表示范圍,可以使用字符串或者數(shù)組,例如1,31或者array(1,31) |
| notbetween | 驗(yàn)證不在某個(gè)范圍,定義的驗(yàn)證規(guī)則表示范圍,可以使用字符串或者數(shù)組(3.1.2版本新增) |
| expire | 驗(yàn)證是否在有效期,定義的驗(yàn)證規(guī)則表示時(shí)間范圍,可以到時(shí)間,例如可以使用 2012-1-15,2013-1-15 表示當(dāng)前提交有效期在2012-1-15到2013-1-15之間,也可以使用時(shí)間戳定義 |
| ip_allow | 驗(yàn)證IP是否允許,定義的驗(yàn)證規(guī)則表示允許的IP地址列表,用逗號(hào)分隔,例如201.12.2.5,201.12.2.6 |
| ip_deny | 驗(yàn)證IP是否禁止,定義的驗(yàn)證規(guī)則表示禁止的ip地址列表,用逗號(hào)分隔,例如201.12.2.5,201.12.2.6 |
| unique | 驗(yàn)證是否唯一,系統(tǒng)會(huì)根據(jù)字段目前的值查詢數(shù)據(jù)庫(kù)來(lái)判斷是否存在相同的值,當(dāng)表單數(shù)據(jù)中包含主鍵字段時(shí)unique不可用于判斷主鍵字段本身 |
驗(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)樽址?
$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)密碼,必須填寫,與密碼保持一致
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)證,必須選一個(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>
結(jié)果:

以上這篇ThinkPHP中create()方法自動(dòng)驗(yàn)證實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
PHP使Laravel為JSON REST API返回自定義錯(cuò)誤的問(wèn)題
這篇文章主要介紹了PHP使Laravel為JSON REST API返回自定義錯(cuò)誤的問(wèn)題,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-10-10
php workerman定時(shí)任務(wù)的實(shí)現(xiàn)代碼
這篇文章主要介紹了php workerman定時(shí)任務(wù)的實(shí)現(xiàn)代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-12-12
laravel yajra插件 datatable的使用詳解
這篇文章主要介紹了laravel yajra插件 datatable的使用詳解,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01
PHP網(wǎng)頁(yè)游戲?qū)W習(xí)之Xnova(ogame)源碼解讀(二)
這篇文章主要介紹了PHP網(wǎng)頁(yè)游戲Xnova(ogame)源碼解讀的安裝文件源碼,需要的朋友可以參考下2014-06-06
PHP隨機(jī)獲取未被微信屏蔽的域名(微信域名檢測(cè))
這篇文章主要介紹了PHP隨機(jī)獲取未被微信屏蔽的域名(微信域名檢測(cè)),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-03-03
分頁(yè)詳解 從此分頁(yè)無(wú)憂(PHP+mysql)
分頁(yè)詳解 從此分頁(yè)無(wú)憂(PHP+mysql)...2007-11-11

