ConstraintViolation是什么?
ConstraintViolation(约束违反)是 Java 中Bean Validation 规范(如 JSR 380,即 Jakarta Bean Validation 2.0)中的核心接口,用于表示数据验证失败时的具体错误信息。它通常在对象属性校验不满足预定义约束(如非空、长度限制、格式校验等)时产生,帮助开发者定位和处理数据验证问题。
一、ConstraintViolation 的核心作用
当使用 Bean Validation 注解(如 @NotNull、@Size、@Email 等)对对象进行校验时,如果属性值不符合注解定义的规则,验证框架会生成一个或多个 ConstraintViolation 实例,每个实例包含:
- 具体哪个对象的哪个属性违反了约束
- 违反的约束规则(如
@NotNull) - 错误提示信息(可自定义)
- 被验证的值(实际传入的不符合规则的值)
二、核心方法解析
ConstraintViolation 接口提供了一系列方法获取验证失败的详细信息,常用方法如下:
| 方法 | 说明 |
|---|---|
getMessage() |
获取错误提示信息(如“不能为空”) |
getMessageTemplate() |
获取错误信息的模板(如 {javax.validation.constraints.NotNull.message}) |
getRootBean() |
获取被验证的根对象(整个校验对象) |
getRootBeanClass() |
获取被验证根对象的类类型 |
getPropertyPath() |
获取违反约束的属性路径(如 user.name) |
getInvalidValue() |
获取导致验证失败的实际值 |
getConstraintDescriptor() |
获取对应的约束注解描述(如 @NotNull 的元信息) |
三、使用场景与示例
1. 定义带约束的实体类
import javax.validation.constraints.Email;
import javax.validation.constraints.NotBlank;
import javax.validation.constraints.Size;
public class User {
@NotBlank(message

最低0.47元/天 解锁文章
703

被折叠的 条评论
为什么被折叠?



