在开发过程中,有时候要对一些变量进行验证,可以自己手写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;
}
- 自定义校验注解
- 新建一个注解类(新建类的时候选择Annotation)
//表示可以在哪些上面添加这个注解(方法,类,变量)
@Target({ElementType.METHOD,ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
//表示通过MyConstrainValidator类定制的规则来验证
@Constraint(validatedBy = MyConstrainValidator.class)
public @interface MyConstraint {
String message();
Class<?>[] groups() default {};
Class<? extends Payload>[] payload() default {};
}
- 新建MyConstrainValidator类,实现ConstraintValidator<T,A>
这里的两个泛型分别是指定给那个类提供规则,验证的类型,可以是String,int
public class MyConstrainValidator implements ConstraintValidator<MyConstraint,Object> {
//在这个方法内进行初始化
@Override
public void initialize(com.imooc.security.imoocsecuritydemo.validator.MyConstraint constraintAnnotation) {
System.out.println("my validator init......");
}
//在这个类中可以注入其他的Service进行一些复杂的验证
/* @Autowired
private HelloService helloService;*/
@Override
public boolean isValid(Object o, ConstraintValidatorContext constraintValidatorContext) {
//在这个方法内编写主要的验证规则
}
}