@Valid注解是什么

@Valid

用于验证注解是否符合要求,直接加在变量user之前,在变量中添加验证信息的要求,当不符合要求时就会在方法中返回message 的错误提示信息。

  1. @RestController
  2. @RequestMapping("/user")
  3. public class UserController {
  4. @PostMapping
  5. public User create (@Valid @RequestBody User user) {
  6. System.out.println(user.getId());
  7. System.out.println(user.getUsername());
  8. System.out.println(user.getPassword());
  9. user.setId("1");
  10. return user;
  11. }
  12. }

然后在 User 类中添加验证信息的要求:

  1. public class User {
  2. private String id;
  3. @NotBlank(message = "密码不能为空")
  4. private String password;
  5. }

@NotBlank 注解所指的 password 字段,表示验证密码不能为空,如果为空的话,上面 Controller 中的 create 方法会将message 中的"密码不能为空"返回。

当然也可以添加其他验证信息的要求:

限制 说明
@Null 限制只能为null
@NotNull 限制必须不为null
@AssertFalse 限制必须为false
@AssertTrue 限制必须为true
@DecimalMax(value) 限制必须为一个不大于指定值的数字
@DecimalMin(value) 限制必须为一个不小于指定值的数字
@Digits(integer,fraction) 限制必须为一个小数,且整数部分的位数不能超过integer,小数部分的位数不能超过fraction
@Future 限制必须是一个将来的日期
@Max(value) 限制必须为一个不大于指定值的数字
@Min(value) 限制必须为一个不小于指定值的数字
@Past 限制必须是一个过去的日期
@Pattern(value) 限制必须符合指定的正则表达式
@Size(max,min) 限制字符长度必须在min到max之间
@Past 验证注解的元素值(日期类型)比当前时间早
@NotEmpty 验证注解的元素值不为null且不为空(字符串长度不为0、集合大小不为0)
@NotBlank 验证注解的元素值不为空(不为null、去除首位空格后长度为0),不同于@NotEmpty,@NotBlank只应用于字符串且在比较时会去除字符串的空格
@Email 验证注解的元素值是Email,也可以通过正则表达式和flag指定自定义的email格式

除此之外还可以自定义验证信息的要求,例如下面的 @MyConstraint:

  1. public class User {
  2. private String id;
  3. @MyConstraint(message = "这是一个测试")
  4. private String username;
  5. }

注解的具体内容:

  1. @Constraint(validatedBy = {MyConstraintValidator.class})
  2. @Target({ELementtype.METHOD, ElementType.FIELD})
  3. @Retention(RetentionPolicy.RUNTIME)
  4. public @interface MyConstraint {
  5. String message();
  6. Class<?>[] groups() default {};
  7. Class<? extends Payload>[] payload() default {};
  8. }

下面是校验器:

  1. public class MyConstraintValidator implements ConstraintValidator<MyConstraint, Object> {
  2. @Autowired
  3. private UserService userService;
  4. @Override
  5. public void initialie(@MyConstraint constarintAnnotation) {
  6. System.out.println("my validator init");
  7. }
  8. @Override
  9. public boolean isValid(Object value, ConstraintValidatorContext context) {
  10. userService.getUserByUsername("seina");
  11. System.out.println("valid");
  12. return false;
  13. }
  14. }

 

 

上一篇:saleor的测试用账户地址"This value is not valid for the address"


下一篇:[刷题] LeetCode 20.Valid Parentheses