加载中...

独立验证


创建验证

任何时候,都可以直接使用think\Validate类而不需要定义验证器类进行独立的验证操作,例如:

  1. $validate = Validate::make([
  2. 'name' => 'require|max:25',
  3. 'email' => 'email'
  4. ]);
  5. $data = [
  6. 'name' => 'thinkphp',
  7. 'email' => 'thinkphp@qq.com'
  8. ];
  9. if (!$validate->check($data)) {
  10. dump($validate->getError());
  11. }

make方法直接传入验证规则(数组),check方法传入需要验证的数据(数组)。

设置规则

也可以使用rule方法设置单个或者批量验证规则,例如:

  1. Validate::make()
  2. ->rule('zip', '/^\d{6}$/')
  3. ->rule('email', 'email')
  4. ->check($data);

支持数组方式

  1. Validate::make()
  2. ->rule(['zip' => '/^\d{6}$/', 'email' => 'email'])
  3. ->check($data);

验证规则可以使用think\validate\ValidateRule对象定义

  1. Validate::make()
  2. ->rule('zip', ValidateRule::regex('/^\d{6}$/'))
  3. ->rule('email', ValidateRule::must()->isEmail())
  4. ->check($data);

ValidateRule类可以静态化调用所有的内置验证方法(支持二个参数:验证规则和错误信息)

下面是指定错误信息及验证字段的名称示例:

  1. Validate::make()
  2. ->rule('zip', ValidateRule::regex('/^\d{6}$/', '邮编错误'))
  3. ->rule('email', ValidateRule::must()->isEmail()->title('邮箱'))
  4. ->rule('name', ValidateRule::min(5, '最少5个字符')->max(20, '不得超过20个字符'))
  5. ->check($data);

同样在数组方式中也支持:

  1. Validate::make()
  2. ->rule([
  3. 'zip' => ValidateRule::regex('/^\d{6}$/'),
  4. 'email' => ValidateRule::email(),
  5. ])
  6. ->check($data);

验证数据

下面是一个典型的验证数据的例子:

  1. $rule = [
  2. 'name' => 'require|max:25',
  3. 'age' => 'number|between:1,120',
  4. 'email' => 'email',
  5. ];
  6. $msg = [
  7. 'name.require' => '名称必须',
  8. 'name.max' => '名称最多不能超过25个字符',
  9. 'age.number' => '年龄必须是数字',
  10. 'age.between' => '年龄只能在1-120之间',
  11. 'email' => '邮箱格式错误',
  12. ];
  13. $data = [
  14. 'name' => 'thinkphp',
  15. 'age' => 10,
  16. 'email' => 'thinkphp@qq.com',
  17. ];
  18. $validate = Validate::make($rule,$msg);
  19. $result = $validate->check($data);
  20. if(!$result) {
  21. dump($validate->getError());
  22. }

如果需要批量验证,可以使用:

  1. $result = Validate::make($rule,$msg)
  2. ->batch()
  3. ->check($data);

批量验证如果验证不通过,返回的是一个错误信息的数组。

闭包验证

可以对某个字段使用闭包验证,例如:

  1. $validate = Validate::make([
  2. 'name' => function($value,$rule) {
  3. return $rule==$value ? true : false;
  4. },
  5. ])->check($data);

自定义验证规则

独立验证的时候支持使用extend方法动态注册验证规则,例如:

  1. $data = ['name' => 1];
  2. $result = Validate::make(['name' => 'checkName:1'])
  3. ->extend('checkName', function ($value, $rule) {
  4. return $rule == $value ? true : '名称错误';
  5. })->check($data);

支持批量注册验证规则,例如:

  1. $data = ['name' => 1];
  2. $result = Validate::make(['name' => 'checkName:1'])
  3. ->extend([
  4. 'checkName'=> function ($value, $rule) {
  5. return $rule == $value ? true : '名称错误';
  6. },
  7. 'checkStatus'=> [$this,'checkStatus']
  8. ])->check($data);

设置字段信息

验证类的架构方法支持传入field参数批量设置字段的描述信息,例如:

  1. $rule = [
  2. 'name' => 'require|max:25',
  3. 'age' => 'number|between:1,120',
  4. 'email' => 'email',
  5. ];
  6. $field = [
  7. 'name' => '名称',
  8. 'age' => '年龄',
  9. 'email' => '邮箱',
  10. ];
  11. $data = [
  12. 'name' => 'thinkphp',
  13. 'age' => 10,
  14. 'email' => 'thinkphp@qq.com',
  15. ];
  16. $validate = Validate::make($rule, [], $field);
  17. $result = $validate->check($data);

错误提示信息

如果要使用自定义的错误信息,可以使用message方法:

  1. $rule = [
  2. 'name' => 'require|max:25',
  3. 'age' => 'number|between:1,120',
  4. 'email' => 'email',
  5. ];
  6. $msg = [
  7. 'name.require' => '名称必须',
  8. 'name.max' => '名称最多不能超过25个字符',
  9. 'age.number' => '年龄必须是数字',
  10. 'age.between' => '年龄必须在1~120之间',
  11. 'email' => '邮箱格式错误',
  12. ];
  13. $data = [
  14. 'name' => 'thinkphp',
  15. 'age' => 121,
  16. 'email' => 'thinkphp@qq.com',
  17. ];
  18. $validate = Validate::make($rule)->message($msg);
  19. $result = $validate->check($data);
  20. if(!$result){
  21. echo $validate->getError();
  22. }

会输出 年龄必须在1~120之间

如果需要使用多语言验证信息,可以在定义验证信息的时候使用 {%语言变量} 替代 原来的验证错误信息,例如:

  1. $rule = [
  2. 'name' => 'require|max:25',
  3. 'age' => 'number|between:1,120',
  4. 'email' => 'email',
  5. ];
  6. $msg = [
  7. 'name.require' => '{%name_require}',
  8. 'name.max' => '{%name_max}',
  9. 'age.number' => '{%age_number}',
  10. 'age.between' => '{%age_between}',
  11. 'email' => '{%email_error}',
  12. ];
  13. $data = [
  14. 'name' => 'thinkphp',
  15. 'age' => 121,
  16. 'email' => 'thinkphp@qq.com',
  17. ];
  18. $validate = Validate::make($rule)->message($msg);
  19. $result = $validate->check($data);
  20. if(!$result){
  21. echo $validate->getError();
  22. }

还没有评论.