validation与 springboot 结合

1. bean 中添加标签

部分代码: 
标签需要加在属性上,@NotBlank 标签含义文章末尾有解释

    1. 
           
        
       
    public class User {2. 
           
        
       
    private Integer id;
    3. 
           
        
       
    "{user.name.notBlank}")
    4. 
           
        
       
    private String name;
    5. 
           
        
       
    private String username;
    • 1
    • 2
    • 3
    • 4
    • 5

    2. Controller中开启验证

    在Controller 中 请求参数上添加@Validated 标签开启验证

    1.  
      @RequestMapping(methodRequestMethod.POST)
    2.  
      public User create(@RequestBody @Validated User user) {
    3.  
      return userService.create(user);
    4.  
      }
    • 1
    • 2
    • 3
    • 4

    3. resource 下新建错误信息配置文件

    注:此处也可不在配置文件中配置,直接在验证的massage中写。

    在resource 目录下新建提示信息配置文件“ValidationMessages.properties“

    注意:名字必须为“ValidationMessages.properties“ 因为SpringBoot自动读取classpath中的ValidationMessages.properties里的错误信息
    • 1
    • 2

    ValidationMessages.properties 文件的编码为ASCII。数据类型为 key value 。key“user.name.notBlank“为第一步 bean的标签 大括号里面对应message的值

    value 为提示信息 ,但是是ASCII 。(内容为“名字不能为空“)

    springboot Autowired列表_配置文件

    4. 自定义异常处理器,捕获错误信息

    当验证不通过时会抛异常出来,在全局异常中定义异常处理器。捕获异常信息(因为验证不通过的项可能是多个所以统一捕获处理),并抛给前端。

    5. 附上部分标签含义



    限制

    说明

    @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格式




    示例

    1. 
           
        
       
    @Pattern(regexp="^[a-zA-Z0-9]+$",message="{account.username.space}")2. 
           
        
       
    @Size(min=3,max=20,message="{account.username.size}")
    3.