SpringBoot使用@valid进行参数校验的流程步骤
Spring Boot 提供了一种方便的方式来进行参数校验:使用 Hibernate Validator。
要在 Spring Boot 应用程序中使用 Hibernate Validator,您需要按照以下步骤进行操作:
1、添加依赖项
在 pom.xml 或 build.gradle 文件中添加以下依赖项:
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-validation</artifactId> </dependency>
2、创建验证器类
创建一个验证器类,该类包含要验证的字段及其规则。例如:
public class MyRequest {
@NotNull(message = "Name cannot be null")
private String name;
@Min(value = 18, message = "Age should not be less than 18")
private int age;
@Email(message = "Email should be valid")
private String email;
// getters and setters
}3、在控制器中使用验证器
将验证器作为参数传递给控制器方法,并使用 @Valid 注释进行注释。例如:
@RestController
@RequestMapping("/api")
public class MyController {
@PostMapping("/users")
public ResponseEntity<?> addUser(@Valid @RequestBody MyRequest request) {
return ResponseEntity.ok().build();
}
}这样就可以在请求中使用 @Valid 注释进行验证,如果不符合条件,则会抛出 ConstraintViolationException 异常。
但是,这样的信息对于开发来说非常杂乱,因此,我们可以用全局异常处理,来统一进行参数验证。通过@ExceptionHandler指定我们需要处理的异常,e.getBindingResult()来获取我们校验后结果对象,如果发生校验失败就通过bindingReslt.getFiledError().getDefaultMessage()获取绑定在对象上面message信息,并返回。

以上就是SpringBoot使用@valid进行参数校验的流程步骤的详细内容,更多关于SpringBoot @valid参数校验的资料请关注脚本之家其它相关文章!
相关文章
SpringBoot种如何使用 EasyExcel 实现自定义表头导出并实现数据格式化转换
本文详细介绍了如何使用EasyExcel工具类实现自定义表头导出,并实现数据格式化转换与添加下拉框操作,通过示例和代码,展示了如何处理不同数据结构和注解,确保数据在导出时能够正确显示和格式化,此外,还介绍了如何解决特定数据类型的转换问题,并提供了解决方案2024-11-11
Java中BigDecimal的舍入模式解析(RoundingMode)
这篇文章主要介绍了Java中BigDecimal的舍入模式解析(RoundingMode),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-06-06
Java GenericObjectPool 对象池化技术之SpringBoot sftp 连接池工具类详解
这篇文章主要介绍了Java GenericObjectPool 对象池化技术之SpringBoot sftp 连接池工具类详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2023-04-04
Spring过滤器中OncePerRequestFilter应用实现
OncePerRequestFilter是Spring框架提供的一个过滤器基类,本文就来介绍一下Spring过滤器中OncePerRequestFilter应用实现,感兴趣的可以了解一下2024-12-12


最新评论