news 2026/4/23 2:29:29

9个Spring Boot参数验证高阶技巧,第8,9个代码量直接减半!

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
9个Spring Boot参数验证高阶技巧,第8,9个代码量直接减半!

9 个 Spring Boot 参数验证高阶技巧(2025–2026 实战版)

Spring Boot 的参数验证(Bean Validation + Hibernate Validator)早已不是简单的@NotNull@Size,下面这些高阶用法可以让你的代码更简洁、更统一、更易维护,尤其是第 8、9 个技巧,真的能把代码量砍一半甚至更多。

1. 自定义复合注解(最常用高阶技巧)

把多个校验规则打包成一个注解,复用性暴增。

@Target({ElementType.FIELD,ElementType.PARAMETER})@Retention(RetentionPolicy.RUNTIME)@Constraint(validatedBy=PhoneNumberValidator.class)@Documentedpublic@interfacePhoneNumber{Stringmessage()default"手机号格式不正确";Class<?>[]groups()default{};Class<?extendsPayload>[]payload()default{};}
publicclassPhoneNumberValidatorimplementsConstraintValidator<PhoneNumber,String>{privatestaticfinalPatternPATTERN=Pattern.compile("^1[3-9]\\d{9}$");@OverridepublicbooleanisValid(Stringvalue,ConstraintValidatorContextcontext){returnvalue!=null&&PATTERN.matcher(value).matches();}}

使用:

@PostMapping("/register")publicResponseregister(@RequestBody@ValidatedRegisterDTOdto){// ...}
publicclassRegisterDTO{@PhoneNumberprivateStringphone;}

2. @Valid + @Validated 的正确组合使用

  • @Valid:用于对象字段嵌套校验(JSR-303 标准)
  • @Validated:Spring 增强版,支持分组校验、类级别校验
publicclassOrderCreateDTO{@NotNullprivateLonguserId;@Valid// 嵌套校验privateList<OrderItemDTO>items;}@PostMapping("/orders")publicvoidcreate(@RequestBody@Validated(Group.Create.class)OrderCreateDTOdto){// ...}

3. 分组校验(Group Validation)——同一个 DTO 不同场景不同规则

publicinterfaceCreate{}publicinterfaceUpdate{}publicclassUserDTO{@Null(groups=Create.class)// 创建时 id 必须为空@NotNull(groups=Update.class)// 更新时 id 必须有privateLongid;@NotBlank(groups={Create.class,Update.class})privateStringusername;}
@PostMapping("/users")publicvoidcreate(@Validated(Create.class)UserDTOdto){...}@PutMapping("/users/{id}")publicvoidupdate(@Validated(Update.class)UserDTOdto){...}

4. 类级别校验(Class-level validation)

校验整个对象,而非单个字段。

@ScriptAssert(lang="javascript",script="_this.startDate.before(_this.endDate)",message="结束时间不能早于开始时间")publicclassActivityDTO{privateLocalDatestartDate;privateLocalDateendDate;}

或者更推荐自定义 Constraint:

@Target({ElementType.TYPE})@Retention(RetentionPolicy.RUNTIME)@Constraint(validatedBy=DateRangeValidator.class)public@interfaceDateRange{Stringmessage()default"结束时间不能早于开始时间";// ...}

5. @JsonView + 校验分组联动

结合@JsonView和分组校验,实现“不同接口不同字段 + 不同校验规则”。

publicinterfaceViews{interfaceCreate{};interfaceUpdate{};}publicclassUserDTO{@Null(groups=Views.Create.class)@NotNull(groups=Views.Update.class)@JsonView({Views.Create.class,Views.Update.class})privateLongid;}

6. MethodValidationPostProcessor 开启方法参数/返回值校验

@ConfigurationpublicclassValidationConfig{@BeanpublicMethodValidationPostProcessormethodValidationPostProcessor(){MethodValidationPostProcessorprocessor=newMethodValidationPostProcessor();processor.setValidator(Validation.buildDefaultValidatorFactory().getValidator());returnprocessor;}}

然后在 Controller/Service 直接用:

@Validated@RestControllerpublicclassUserController{@PostMapping("/users")publicUsercreateUser(@Valid@RequestBodyUserDTOdto){// ...}}

7. 自定义全局异常处理器 + 统一错误响应

@RestControllerAdvicepublicclassGlobalExceptionHandler{@ExceptionHandler(ConstraintViolationException.class)@ResponseStatus(HttpStatus.BAD_REQUEST)publicRhandleConstraintViolation(ConstraintViolationExceptione){List<String>errors=e.getConstraintViolations().stream().map(v->v.getMessage()).toList();returnR.error(400,"参数校验失败",errors);}@ExceptionHandler(MethodArgumentNotValidException.class)publicRhandleMethodArgumentNotValid(MethodArgumentNotValidExceptione){List<String>errors=e.getBindingResult().getFieldErrors().stream().map(FieldError::getDefaultMessage).toList();returnR.error(400,"参数校验失败",errors);}}

8. 使用 @Validated + Record(代码量直接砍一半!)

Java 14+ Record + 校验 = 极简 DTO

@ValidatedpublicrecordUserCreateRequest(@NotBlank(message="用户名不能为空")@Size(min=4,max=20)Stringusername,@NotBlank@EmailStringemail,@PhoneNumberStringphone){}

Controller 直接用:

@PostMapping("/users")publicvoidcreate(@ValidUserCreateRequestrequest){// request.username() 访问}

对比传统:省去 getter/setter、equals/hashCode、toString,代码量直接减半以上。

9. 使用 hibernate-validator 内置的 @ParameterNameProvider + @ConstraintValidatorContext 动态消息

终极简化:字段名自动映射中文提示

@ConfigurationpublicclassValidationConfig{@BeanpublicValidatorvalidator(){ValidatorFactoryfactory=Validation.byDefaultProvider().configure().parameterNameProvider(newCustomParameterNameProvider()).buildValidatorFactory();returnfactory.getValidator();}staticclassCustomParameterNameProviderimplementsParameterNameProvider{@OverridepublicList<String>getParameterNames(Constructor<?>constructor){returnArrays.stream(constructor.getParameters()).map(p->p.isAnnotationPresent(NotBlank.class)?"用户名":p.getName()).toList();}// ...}}

更推荐:直接用@Property或自定义MessageInterpolator

但最直接省代码的方式还是第 8 点:Record + @Validated

总结:最值得立刻掌握的三个

  • 第 1:自定义复合注解(复用性最高)
  • 第 3:分组校验(同一个 DTO 多种场景)
  • 第 8:Record + @Validated(代码量直接减半,强烈推荐!)

你项目里现在是用传统 DTO 还是已经开始用 Record 了?
或者在校验上遇到过哪些最头疼的场景?可以告诉我,我帮你针对性给出更优解法。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 9:44:22

科研党收藏!更贴合专科生的降AI率网站,千笔AI VS PaperRed

在AI技术迅猛发展的今天&#xff0c;越来越多的专科生开始借助AI工具辅助完成论文写作&#xff0c;以提高效率、优化内容。然而&#xff0c;随着学术审查标准的不断提升&#xff0c;AI生成内容的痕迹愈发明显&#xff0c;查重率和AIGC检测成为论文通过的关键障碍。面对市场上种…

作者头像 李华
网站建设 2026/4/23 9:46:32

路由懒加载的3种实现方式与性能对比

路由懒加载的3种实现方式与性能对比 在单页应用&#xff08;SPA&#xff09;开发中&#xff0c;路由懒加载是优化首屏加载性能的核心策略之一。其核心思想是将路由对应的组件代码拆分为独立文件&#xff0c;仅在用户访问时动态加载&#xff0c;从而减少初始包体积&#xff0c;提…

作者头像 李华
网站建设 2026/4/23 9:49:19

救命神器 8个降AIGC软件测评:本科生降AI率必备工具推荐

在如今的学术写作中&#xff0c;AI生成内容&#xff08;AIGC&#xff09;已经成为高校和科研机构关注的重点。尤其对于本科生而言&#xff0c;如何有效降低论文中的AI痕迹、提升原创性&#xff0c;成为毕业论文顺利通过的重要环节。随着查重系统对AI生成内容的识别能力不断提升…

作者头像 李华
网站建设 2026/4/23 9:47:54

基于Spring Boot的少儿编程管理系统设计与实现(开题报告)

毕业论文(设计)开题报告基于Spring Boot的少儿编程管理系统设计与实现 姓 名 学 院 数学与数据科学学院 专业班级 信息与计算科学211 学 号 指导教师 ; 职称/职务 副教授;技术经理 起始时间 2025年5月9日 教务部制 一、开题依据(研究目的、意义及国内外研究概况,附主…

作者头像 李华
网站建设 2026/4/23 9:48:36

RTOS核心三剑客:任务、信号量与队列深度解析

RTOS核心三剑客&#xff1a;任务、信号量与队列深度解析 一、裸机编程的瓶颈&#xff1a;为什么需要RTOS&#xff1f; 在嵌入式开发中&#xff0c;裸机程序通常采用**超级循环(Super Loop)**结构&#xff1a; void main() { while(1) { read_sensors();// 读取传感器 process_d…

作者头像 李华
网站建设 2026/4/23 9:50:55

AI专著写作指南:精选工具推荐,帮你高效完成学术专著创作

学术专著写作&#xff1a;挑战与AI解决方案 学术专著写作的挑战不仅在于“能否写出来”&#xff0c;更在于“能否成功出版并获得认可”。学术专著的受众通常较为有限&#xff0c;因此出版社在选题时会严格审核其学术价值和作者的影响力。许多作者即使完成了初步的书稿&#xf…

作者头像 李华