SpringBoot整合Hibernate Validator详细教程
26 浏览量
更新于2024-09-02
收藏 148KB PDF 举报
"SpringBoot使用hibernate validator进行数据校验的方法和示例"
在SpringBoot应用中,使用Hibernate Validator能够方便地实现数据校验,确保输入的数据符合预设的规则。下面将详细介绍如何配置和使用Hibernate Validator进行校验。
1. 引入依赖
在SpringBoot项目中,我们只需引入`spring-boot-starter-web`依赖,因为该依赖已经包含了Hibernate Validator。如果你的项目还没有引入,可以添加以下Maven或Gradle依赖:
Maven:
```xml
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
```
Gradle:
```groovy
implementation 'org.springframework.boot:spring-boot-starter-web'
```
2. 常用校验注解
Hibernate Validator提供了多种注解用于字段的校验,例如:
- `@NotBlank`: 验证字符串不为空且不包含空格。
- `@Size`: 验证字符串长度或集合大小在指定范围内。
- `@NotNull`: 验证对象非空。
- `@Past`: 验证日期在过去。
- `@Range`: 验证数值在指定范围内。
3. 简单的实体校验
在实体类中,我们可以在字段上添加这些注解,比如在`CardDTO`类中的`cardId`、`cardNum`、`createDate`和`cardType`字段上添加相应的注解,然后在Controller中使用`@RequestBody`和`@Valid`注解来触发校验。例如:
```java
@PostMapping("simple")
public Object simple(@RequestBody @Valid CardDTO cardDTO) {
return cardDTO;
}
```
4. 复杂的实体校验
- 嵌套实体校验:当需要校验嵌套实体时,如`UserDTO`类中包含`List<CardDTO>`,只需在嵌套实体字段(如`cardList`)上添加`@Valid`注解,Hibernate Validator会递归进行校验。
- List<DTO>校验:对于列表类型的字段,直接在`List`上使用`@Valid`是无效的。我们需要创建一个新的实体类,比如`ValidCardListDTO`,其中包含`List<CardDTO>`,然后在`ValidCardListDTO`上使用`@Valid`,这样就能实现列表的校验。
5. 自定义校验注解
如果内置的注解无法满足需求,我们可以创建自定义校验注解,并编写对应的校验器。自定义注解需要使用`@Constraint`注解,校验器实现`ConstraintValidator`接口。
6. 错误处理
当数据校验失败时,SpringBoot默认会返回一个带有错误信息的HTTP 400响应。你可以自定义错误处理器,比如通过实现`HandlerExceptionResolver`接口,捕获并处理`MethodArgumentNotValidException`异常,返回自定义的错误响应。
总结来说,SpringBoot结合Hibernate Validator提供了一套强大的数据校验机制,通过简单的注解就能完成各种复杂的数据验证,保证了应用的数据质量。通过理解并熟练运用这些校验注解和机制,开发者可以编写出更加健壮和易维护的代码。
2020-08-18 上传
2020-08-25 上传
2020-08-19 上传
点击了解资源详情
2020-08-28 上传
点击了解资源详情
点击了解资源详情
点击了解资源详情
2020-08-25 上传