@Valid和BindingResult的使用

在开发过程中,有时候要对一些变量进行验证,可以自己手写if来进行验证,也可以使用第三方框架,使用第三方框架相对来说简单一点,只需要添加一个注解,也可以自己定义注解

  • 如果想要对一个变量进行校验,那就再这个变量上添加相应的注解,比如不能为空就是用**@NotBlank(message = “密码不能为空”)**里面的message可以自己定义,message中的值就是如果不满足条件的话,就给用户这个提示,还有很多注解,可以自己去学习
  • 然后在使用了包含这个变量的对象的方法参数前添加@Valid,如果不满足条件的话,不会进入方法体,如果使用了BindingResult就会进入方法体,并且将错误添加到了BindingResult对象中
 @PutMapping("/{id:\\d+}")public User update(@Valid  @RequestBody User user, BindingResult errors) {//将BindingResult中的错误信息打印在控制台if (errors.hasErrors()) {errors.getAllErrors().stream().forEach(error -> {/* FieldError fieldError = (FieldError) error;String message = fieldError.getField() + error.getDefaultMessage();*/System.out.println(error.getDefaultMessage());});}//可以在这里进行相应的操作return user;}
  • 自定义校验注解
  1. 新建一个注解类(新建类的时候选择Annotation)
//表示可以在哪些上面添加这个注解(方法,类,变量)
@Target({ElementType.METHOD,ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
//表示通过MyConstrainValidator类定制的规则来验证
@Constraint(validatedBy = MyConstrainValidator.class)
public @interface MyConstraint {String message();Class[] groups() default {};Class[] payload() default {};
}
  1. 新建MyConstrainValidator类,实现ConstraintValidator
    这里的两个泛型分别是指定给那个类提供规则,验证的类型,可以是String,int
public class MyConstrainValidator implements ConstraintValidator {//在这个方法内进行初始化@Overridepublic void initialize(com.imooc.security.imoocsecuritydemo.validator.MyConstraint constraintAnnotation) {System.out.println("my validator init......");}//在这个类中可以注入其他的Service进行一些复杂的验证/* @Autowiredprivate HelloService helloService;*/@Overridepublic boolean isValid(Object o, ConstraintValidatorContext constraintValidatorContext) {//在这个方法内编写主要的验证规则}}


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部