前言

        最近工作,毕业设计都忙疯了,辞了工作现在终于有空余时间可以继续总结了



Spring数据校验

        Spring有自己的校验框架,同时也支持JSR 303 的校验,这里主要介绍Spring使用JSR 303的校验,Spring的校验框架主要方法org.springframework.vaildation包中。需要注意,Spring并没有提供JSR 303规范的实现,所以必须添加JSR303的实现者jar包(比如Hibernate Validator),Spring JSR 303 校验使用相当简单,只需要在需要验证的Bean中加入验证的注解,再在Sping MVC 方法入参时,在该Bean前面加上@Valid即可,例:

public Class user {
    private String userId;
    
    //使用正则表达式效验,匹配4~30个数字或字母或下划线的字符
    @Pattern(regexp="w{4, 30}")
    private String userName;
    
    //长度在8~20之间
    @Length(min=8, max=20)
    private String passWord;
    
    //时间必须是过去的时间
    @Past
    @DateTimeFormat(pattern="yyy-MM-dd")
    private Date createDate;
    
    //数据必须大于1000小于100000
    @DecimalMin(value="1000.00")
    @DeciamlMax(value="100000.00")
    @NumberFormat(pattern="#,###.##")
    private long salary;
}
public Class user {
    private String userId;
    
    //使用正则表达式效验,匹配4~30个数字或字母或下划线的字符
    @Pattern(regexp="w{4, 30}")
    private String userName;
    
    //长度在8~20之间
    @Length(min=8, max=20)
    private String passWord;
    
    //时间必须是过去的时间
    @Past
    @DateTimeFormat(pattern="yyy-MM-dd")
    private Date createDate;
    
    //数据必须大于1000小于100000
    @DecimalMin(value="1000.00")
    @DeciamlMax(value="100000.00")
    @NumberFormat(pattern="#,###.##")
    private long salary;
}

Controller中:

@Controller
public class UserController {
    
    @RequestMapping(value = "/user", method = RequestMethod.POST)
    public String addUser(@Valid User user, BindingResult result) {
       ......
    }
}
@Controller
public class UserController {
    
    @RequestMapping(value = "/user", method = RequestMethod.POST)
    public String addUser(@Valid User user, BindingResult result) {
       ......
    }
}

在Spring MVC将User对象绑定入参后会进行校验,结果会放在后面的BindingResult或者Errors对象中。

注意:BindingResult或者Errors必须紧跟在需要验证的Bean后面,如果其间有其他的入参会直接报异常

用于效验的Annotation:

@AssertTrue / @AssertFalse 

  • 验证适用字段:boolean
  • 注解说明:验证值是否为true / false
  • 属性说明:-

@DecimalMax / @DecimalMin 

  • 验证适用字段:BigDecimal,BigInteger,String,byte,short,int,long
  • 注解说明:验证值是否小于或者等于指定的小数值,要注意小数存在精度问题
  • 属性说明:公共

@Digits 

  • 验证适用字段:BigDecimal,BigInteger,String,byte,short,int,long
  • 注解说明:验证值的数字构成是否合法
  • 属性说明:integer:指定整数部分的数字的位数。fraction: 指定小数部分的数字的位数。

@Future / @Past 

  • 验证适用字段:Date,Calendar
  • 注解说明:验证值是否在当前时间之后 / 之前
  • 属性说明:公共

@Max / @Min 

  • 验证适用字段:BigDecimal,BigInteger,String,byte,short,int,long
  • 注解说明:验证值是否小于或者等于指定的整数值
  • 属性说明:公共

@NotNull / @Null 

  • 验证适用字段:引用数据类型
  • 注解说明:验证值是否为非空 / 空
  • 属性说明:公共

@Pattern 

  • 验证适用字段:String
  • 注解说明:验证值是否配备正则表达式
  • 属性说明:regexp:正则表达式flags: 指定Pattern.Flag 的数组,表示正则表达式的相关选项。

@Size 

  • 验证适用字段:String,Collection,Map,数组
  • 注解说明:验证值是否满足长度要求
  • 属性说明:max:指定最大长度,min:指定最小长度。