1. 概述
数据验证是企业应用开发中必备可少的环节,通常如果使用if-else
在业务代码中写死验证逻辑,会导致验证逻辑与业务逻辑耦合。
2. 不合理的验证方式
public class BadDemo {
public void bad(String str){
if(null == str){
throw new NullPointerException("str 不能为空");
}
// todo 业务逻辑
}
}
上述代码,如果需要修改验证,
str
不为空且长度大于8
,只能强行修改代码。
3. 优雅的数据验证方式
3.1. 添加pom.xml
依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
3.2 创建实体类
@Data
public class User {
@NotNull(message = "名字不能为空")
@Length(min = 4, max = 10, message = "name 长度必须在 {min} - {max} 之间")
private String name;
@NotNull(message = "年龄不能为空")
@Min(value = 18, message = "年龄不能小于18岁")
private Integer age;
}
JSR-303
注解解释
注解 | 说明 |
---|---|
@NotNull | 限制必须不为null |
@NotEmpty | 验证注解的元素值不为 null 且不为空(字符串长度不为0、集合大小不为0) |
@NotBlank | 验证注解的元素值不为空(不为null、去除首位空格后长度为0),不同于@NotEmpty,@NotBlank只应用于字符串且在比较时会去除字符串的空格 |
@Pattern(value) | 限制必须符合指定的正则表达式 |
@Size(max,min) | 限制字符长度必须在 min 到 max 之间(也可以用在集合上) |
@Email | 验证注解的元素值是Email,也可以通过正则表达式和flag指定自定义的email格式 |
@Max(value) | 限制必须为一个不大于指定值的数字 |
@Min(value) | 限制必须为一个不小于指定值的数字 |
@DecimalMax(value) | 限制必须为一个不大于指定值的数字 |
@DecimalMin(value) | 限制必须为一个不小于指定值的数字 |
@Null | 限制只能为null(很少用) |
@AssertFalse | 限制必须为false (很少用) |
@AssertTrue | 限制必须为true (很少用) |
@Past | 限制必须是一个过去的日期 |
@Future | 限制必须是一个将来的日期 |
@Digits(integer,fraction) | 限制必须为一个小数,且整数部分的位数不能超过 integer,小数部分的位数不能超过 fraction (很少用) |
- 这里只列举了 javax.validation
包下的注解,同理在 spring-boot-starter-web
包中也存在hibernate-validator
验证包,里面包含了一些 javax.validation
没有的注解,有兴趣的可以看看
3.3 Controller
层
@Validated
@RestController
public class UserController {
@PostMapping("/user")
public R addUser(@Validated @RequestBody User user, BindingResult br){
if(br.hasErrors()){
return R.isFail().msg(br.getFieldError().getDefaultMessage());
} else {
return R.isOk().data(user);
}
}
@GetMapping("/user")
public R test2(
@NotBlank(message = "name 不能为空")
@Length(min = 2, max = 10, message = "name 长度必须在 {min} - {max} 之间")
String name ) {
return R.isOk().data(name);
}
}
注解解释
-@Validated
: 开启数据有效性校验,添加在类上即为验证方法,添加在方法参数中即为验证参数对象。(添加在方法上无效)
-@NotBlank
: 被注释的字符串不允许为空
-@Length
: 被注释的字符串的大小必须在指定的范围内
-@NotNull
: 被注释的字段不允许为空
-@DecimalMin
: 被注释的字段必须大于或等于指定的数值
4. 测试结果
5. 工程目录
6. 结束语
说点什么呢,有任何建议,欢迎留言探讨,本文源码。
欢迎关注博主公众号,第一时间推送最新文章