使用SpringMVC时配合hibernate-validate进行参数的合法性校验,能节省一定的代码量。

1.搭建Web工程并引入hibernate-validate依赖

<dependency>
<groupId>org.hibernate.validator</groupId>
<artifactId>hibernate-validator</artifactId>
<version>6.0..Final</version>
</dependency>

Maven依赖传递,自动依赖validation-api、jboss-logging、classmate。

2.使用校验注解标注在属性上(DTO)

*每个注解都有message属性,该属性用于填写校验失败时的异常描述信息,当校验失败时可以获取对应的message属性值。

public class User {

    @NotNull(message="id不能为空!")
private Integer id; @NotBlank(message="用户名不能为空!")
@Size(min=4,max=12,message="用户名的长度在4~12之间!")
private String username; @NotBlank(message="密码不能为空!")
private String password; @Email(message="非法邮箱!")
private String email; public Integer getId() {
return id;
} public void setId(Integer id) {
this.id = id;
} public String getUsername() {
return username;
} public void setUsername(String username) {
this.username = username;
} public String getPassword() {
return password;
} public void setPassword(String password) {
this.password = password;
} public String getEmail() {
return email;
} public void setEmail(String email) {
this.email = email;
} public User() {
super();
} }

3.控制层中使用DTO接收参数并使用@Validated/@Valid注解开启对参数的校验

 

*@Validated注解表示开启Spring的校验机制,支持分组校验,声明在入参上。

*@Valid注解表示开启Hibernate的校验机制,不支持分组校验,声明在入参上。

*在DTO后面紧跟BindingResult对象,那么当参数不符合时,能通过该对象直接获取不符合校验的message描述信息。

*若使用了@Validated/@Valid注解开启校验,但DTO后面没有紧跟BindingResult对象,那么当参数不符合时,将直接返回400 Bad Request状态码。

@RestController
public class BaseController { @RequestMapping("/test")
public User test(@Validated User user, BindingResult result) {
if (result.hasErrors()) {
List<ObjectError> errors = result.getAllErrors();
for (ObjectError error : errors) {
System.out.println(error.getDefaultMessage());
}
}
return user;
} }

演示:

结果:

密码不能为空!
id不能为空!
用户名的长度在4~12之间!

*校验的顺序是随机的,因此程序不能依赖校验的顺序去做相关的逻辑处理。

4.分组校验

每个校验注解都有group属性用于指定校验所属的组,其值是Class数组,在Controller中使用@Validated注解开启对参数的校验时若指定要进行校验的组,那么只有组相同的属性才会被进行校验(默认全匹配)

Class<?>[] groups() default { };

一般定义标识接口作为组资源

public interface GroupA {

}

public interface GroupB {

}

使用校验注解标注在属性上并进行分组

public class User {

    @NotNull(message="id不能为空!",groups = {GroupA.class})
private Integer id; @NotBlank(message="用户名不能为空!",groups = {GroupB.class})
@Size(min=4,max=12,message="用户名的长度在4~12之间!")
private String username; @NotBlank(message="密码不能为空!")
private String password; @Email(message="非法邮箱!")
private String email; public Integer getId() {
return id;
} public void setId(Integer id) {
this.id = id;
} public String getUsername() {
return username;
} public void setUsername(String username) {
this.username = username;
} public String getPassword() {
return password;
} public void setPassword(String password) {
this.password = password;
} public String getEmail() {
return email;
} public void setEmail(String email) {
this.email = email;
} public User() {
super();
} }

Controller中使用@Validated注解开启对参数的校验并指定校验的组,那么只有组相同的属性才会被进行校验(默认全匹配)

@RestController
public class BaseController { @RequestMapping("/test")
public User test(@Validated(value= {GroupB.class}) User user, BindingResult result) {
if (result.hasErrors()) {
List<ObjectError> errors = result.getAllErrors();
for (ObjectError error : errors) {
System.out.println(error.getDefaultMessage());
}
}
return user;
} }

演示:

结果:

用户名不能为空!

*后端一般只返回重名等错误描述信息,对于非空、字符长度、手机邮箱合法性校验等由前端进行判断并提示,后端校验不通过时不返回错误描述信息,所以不需要使用BindingResult获取错误描述,当参数不符合时直接返回400 Bad Request请求。

最新文章

  1. C#测试题若干,都是基础阿
  2. 【转】根据中国气象局提供的API接口实现天气查询
  3. Android 自定义控件(一)
  4. JMeter学习-007-JMeter 断言实例之一 - 响应断言
  5. Pig与Hive的区别
  6. UWP好文
  7. Setting property &#39;source&#39; to &#39;org.eclipse.jst.jee.server
  8. 如何彻底卸载MySQL
  9. ARM--存储管理器
  10. d008: 求两数的整数商 和 商
  11. gulp使用心得
  12. 遗传算法Matlab源程序
  13. EventUtil.addHandler方法
  14. QVector常见使用方法
  15. C实现 C++ map
  16. python之使用heapq()函数计算列表中数值大小
  17. cdqz2017-test11-占卜的准备
  18. AOP 实现自定义注解
  19. 详解MySQL数据表类型
  20. POJ2739 Sum of Consecutive Prime Numbers 2017-05-31 09:33 47人阅读 评论(0) 收藏

热门文章

  1. 三级级联查询省份名称和编码(保证名称不重复)的SQL语句
  2. 芝麻HTTP:Scrapy-Splash的安装
  3. Java序列化机制和原理及自己的理解
  4. 浅谈js中null和undefined的区别
  5. [BZOJ3207] 花神的嘲讽计划Ⅰ (主席树)
  6. java中获取所有的请求参数
  7. SpringBoot初探之Swagger配置
  8. eclipse中Maven项目pom.xml报错:com.thoughtworks.xstream.io.HierarchicalStreamDriver
  9. 文件导出也可以这么写【js+blob】
  10. 1111 WordReplace