模型验证

最后更新于:2022-04-01 21:25:13

在模型中的验证方式如下: ~~~ $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()); } ~~~ > 第二个参数如果不传的话,则采用默认的错误提示信息。 如果使用下面的验证器类的话: ~~~ 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; // 调用当前模型对应的User验证器类进行数据验证 $result = $User->validate(true)->save($data); if(false === $result){ // 验证失败 输出错误信息 dump($User->getError()); } ~~~ 如果需要调用的验证器类和当前的模型名称不一致,则可以使用: ~~~ $User = new User; // 调用Member验证器类进行数据验证 $result = $User->validate('Member')->save($data); if(false === $result){ // 验证失败 输出错误信息 dump($User->getError()); } ~~~ 同样也可以支持场景验证: ~~~ $User = new User; // 调用Member验证器类进行数据验证 $result = $User->validate('User.edit')->save($data); if(false === $result){ // 验证失败 输出错误信息 dump($User->getError()); } ~~~
';