模型驗證

在模型中的驗證方式如下:

$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

文檔
目錄

深色
模式

切換
寬度