模型驗證
在模型中的驗證方式如下:
$User = new User;
$result = $User->validate(
[
'name' => 'require|max:25',
'email' => 'email',
],
[
'name.require' => '名稱必須',
'name.max' => '名稱最多不能超過25個字符',
'email' => '郵箱格式錯誤',
]
)->save($data);
if(false === $result){
// 驗證失敗 輸出錯誤信息
dump($User->getError());
}
第二個參數(shù)如果不傳的話,則采用默認的錯誤提示信息。
如果使用下面的驗證器類的話:
namespace app\index\validate;
use think\Validate;
class User extends Validate
{
protected $rule = [
'name' => 'require|max:25',
'email' => 'email',
];
protected $message = [
'name.require' => '用戶名必須',
'email' => '郵箱格式錯誤',
];
protected $scene = [
'add' => ['name','email'],
'edit' => ['email'],
];
}
模型驗證代碼可以簡化為:
$User = new User;
// 調(diào)用當前模型對應(yīng)的User驗證器類進行數(shù)據(jù)驗證
$result = $User->validate(true)->save($data);
if(false === $result){
// 驗證失敗 輸出錯誤信息
dump($User->getError());
}
如果需要調(diào)用的驗證器類和當前的模型名稱不一致,則可以使用:
$User = new User;
// 調(diào)用Member驗證器類進行數(shù)據(jù)驗證
$result = $User->validate('Member')->save($data);
if(false === $result){
// 驗證失敗 輸出錯誤信息
dump($User->getError());
}
同樣也可以支持場景驗證:
$User = new User;
// 調(diào)用Member驗證器類進行數(shù)據(jù)驗證
$result = $User->validate('User.edit')->save($data);
if(false === $result){
// 驗證失敗 輸出錯誤信息
dump($User->getError());
}
文檔最后更新時間:2018-04-26 10:47:18
← 控制器驗證
內(nèi)置規(guī)則 →
未解決你的問題?請到「問答社區(qū)」反饋你遇到的問題