当前位置: 首页 > news >正文

关于 javax.validation.constraints的详细说明

以下是关于 javax.validation.constraints(现为 ​Jakarta Bean Validation)的详细说明,涵盖核心注解、使用场景、代码示例及最佳实践:


一、javax.validation.constraints 是什么?

  • 作用​:提供一组标准注解,用于对 Java Bean 的字段或方法参数进行数据校验(如非空、长度、范围等)。
  • 规范演进​:
    • Java EE 时期:包名为 javax.validation.constraints
    • Jakarta EE 9+:包名迁移为 jakarta.validation.constraints(需注意依赖兼容性)。

二、核心注解列表及用法

1. 常用注解
注解校验规则支持类型
@NotNull值不能为 null任意类型
@NotBlank字符串不能为空或纯空格String
@NotEmpty集合/数组/字符串不能为空(长度 > 0)Collection, String
@Size(min, max)元素数量或字符串长度在指定范围内集合、数组、字符串
@Min(value)数值必须 ≥ 指定最小值数值类型(int, long 等)
@Max(value)数值必须 ≤ 指定最大值同上
@DecimalMin(value)数值必须 ≥ 指定最小值(字符串形式,支持精度)BigDecimal, String
@DecimalMax(value)数值必须 ≤ 指定最大值(字符串形式,支持精度)同上
@Digits(integer, fraction)数值整数部分最多 integer 位,小数部分最多 fraction数值类型
@Pattern(regexp)字符串必须匹配正则表达式String
@Email字符串必须是合法邮箱格式String
@Positive / @PositiveOrZero数值必须为正数或零数值类型
@Negative / @NegativeOrZero数值必须为负数或零数值类型
@Future / @FutureOrPresent日期必须在未来(或包含当前)Date, LocalDate
@Past / @PastOrPresent日期必须在过去(或包含当前)同上
2. 注解示例代码
public class User {@NotBlank(message = "用户名不能为空")private String username;@Email(message = "邮箱格式无效")private String email;@Size(min = 6, max = 20, message = "密码长度需在6-20位之间")private String password;@Min(value = 18, message = "年龄必须≥18岁")@Max(value = 100, message = "年龄必须≤100岁")private Integer age;@Pattern(regexp = "^1[3-9]\\d{9}$", message = "手机号格式无效")private String phone;
}

三、集成到 Spring Boot 中的步骤

1. 添加依赖
<!-- Spring Boot 2.x 使用 javax.validation -->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-validation</artifactId>
</dependency><!-- Jakarta EE 9+ 使用 jakarta.validation -->
<dependency><groupId>jakarta.validation</groupId><artifactId>jakarta.validation-api</artifactId><version>3.0.2</version>
</dependency>
2. 在 Controller 中触发校验

使用 @Valid@Validated 注解触发校验:

@PostMapping("/users")
public ResponseEntity<?> createUser(@RequestBody @Valid User user) {// 校验通过后执行业务逻辑return ResponseEntity.ok("用户创建成功");
}
3. 处理校验异常

通过 @ExceptionHandler 捕获 MethodArgumentNotValidException

@RestControllerAdvice
public class GlobalExceptionHandler {@ExceptionHandler(MethodArgumentNotValidException.class)public ResponseEntity<Map<String, String>> handleValidationException(MethodArgumentNotValidException ex) {Map<String, String> errors = new HashMap<>();ex.getBindingResult().getAllErrors().forEach(error -> {String fieldName = ((FieldError) error).getField();String errorMessage = error.getDefaultMessage();errors.put(fieldName, errorMessage);});return ResponseEntity.badRequest().body(errors);}
}

四、高级用法

1. 分组校验

通过分组接口实现不同场景下的差异化校验:

// 定义分组接口
public interface CreateGroup {}
public interface UpdateGroup {}public class User {@NotNull(groups = UpdateGroup.class)private Long id;@NotBlank(groups = {CreateGroup.class, UpdateGroup.class})private String name;
}// 在 Controller 中指定分组
@PostMapping("/users")
public ResponseEntity<?> createUser(@RequestBody @Validated(CreateGroup.class) User user) { ... }
2. 自定义校验注解

实现自定义校验逻辑(如密码强度校验):

@Target({FIELD})
@Retention(RUNTIME)
@Constraint(validatedBy = PasswordValidator.class)
public @interface StrongPassword {String message() default "密码必须包含大小写字母和数字";Class<?>[] groups() default {};Class<? extends Payload>[] payload() default {};
}public class PasswordValidator implements ConstraintValidator<StrongPassword, String> {@Overridepublic boolean isValid(String password, ConstraintValidatorContext context) {return password.matches("^(?=.*[a-z])(?=.*[A-Z])(?=.*\\d).+$");}
}
3. 级联校验

校验对象内的嵌套对象:

public class Order {@Validprivate List<@Valid Product> products; // 校验每个 Product 的字段
}

五、校验失败的错误消息定制

1. 默认消息模板

每个注解的 message 属性支持占位符:

@Size(min = 6, max = 20, message = "密码长度需在{min}-{max}位之间")
private String password;
2. 国际化消息

messages.propertiesValidationMessages.properties 中定义:

user.email.invalid=邮箱格式无效

注解中使用:

@Email(message = "{user.email.invalid}")
private String email;

六、常见问题与解决方案

问题解决方案
校验未生效检查是否添加了 @Valid@Validated 注解;确认依赖已正确引入
嵌套对象校验失败在嵌套对象字段上添加 @Valid 注解
分组校验不生效@Validated 注解中明确指定分组接口
自定义校验器未触发确认 @Constraint(validatedBy = MyValidator.class) 并实现 ConstraintValidator

七、总结

  • 核心价值​:通过声明式注解简化数据校验逻辑,减少样板代码。
  • 最佳实践​:
    • 优先使用标准注解,避免重复造轮子。
    • 结合分组校验实现多场景复用。
    • 统一处理校验异常,返回清晰的错误信息。
  • 扩展性​:通过自定义注解和校验器满足复杂业务需求。

相关文章:

  • HuggingFace的SafeSensor格式模型能转成Ollama格式的吗?
  • 26、测试咒语:魔法校验—— Jest+Testing Lib
  • SimpleAdmin云服务器发布
  • 浅聊一下数据库的索引优化
  • 19.Excel数据透视表:第2部分数据透视计算
  • 生产级编排AI工作流套件:Flyte全面使用指南 — Core concepts
  • 需求管理缺乏持续改进机制,如何建立
  • 计算机视觉----时域频域在图像中的意义、傅里叶变换在图像中的应用、卷积核的频域解释
  • 黑白浮生项目测试报告
  • 【入门】纸盒的最大体积是多少?
  • docker部署WeDataSphere开源大数据平台
  • redis数据结构-10(ZREM、ZSCORE、ZINCRBY)
  • 以价值为导向的精准数据治理实践,赋能业务决策
  • 移动端前端开发调试工具/webkit调试工具/小程序调试工具WebDebugX使用教程
  • 第十五届蓝桥杯国赛Python A组题解
  • 【认知思维】沉没成本谬误:为何难以放弃已投入的资源
  • 山东大学软件学院计算机图形学2025期末考题回忆版
  • 使用bitNet架构
  • 普通IT的股票交易成长史--20250513复盘
  • CAN(控制器局域网络)协议详解
  • 广西北部湾国际港务集团副总经理潘料庭接受审查调查
  • 袁思达已任中国科学院办公厅主任
  • 中哥两国元首共同见证签署《中华人民共和国政府与哥伦比亚共和国政府关于共同推进丝绸之路经济带和21世纪海上丝绸之路建设的合作规划》
  • “75万买299元路由器”事件进展:重庆市纪委等三部门联合介入调查
  • 商务部就开展打击战略矿产走私出口专项行动应询答记者问
  • 城事 | 重庆新增热门打卡地标,首座熊猫主题轨交站亮相