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

SpringBoot自定义实体类字段的校验注解

在Spring Boot项目中,我们经常需要对请求参数进行格式或业务规则的校验。虽然Spring Boot提供了如@NotNull、@Size等基础校验注解,但在实际开发中往往无法满足复杂的业务需求。但是在Controller层写大量的 if 语句的判断逻辑又实在不优雅,好在 Spring Validator 为我们提供了一种自定义校验注解的方法实现优雅的参数校验。

简而言之,自定义校验注解的优点大概有以下几点:

  • 统一性:避免在Controller层写大量if判断逻辑
  • 可复用性:可以在多个字段或多个实体类中重复使用
  • 可维护性:校验逻辑和业务逻辑分离,便于后期修改和扩展

自定义校验注解的实现步骤:

一、 创建自定义注解类
import javax.validation.Constraint;
import javax.validation.Payload;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;@Target({ElementType.FIELD, ElementType.PARAMETER})
@Retention(RetentionPolicy.RUNTIME)
@Constraint(validatedBy = ValidN1Validator.class)
public @interface ValidN1 {String message() default "必须1位数字";Class<?>[] groups() default {};Class<? extends Payload>[] payload() default {};
}

解析

1. @Target({ElementType.FIELD, ElementType.PARAMETER}):表示该注解可以用于字段或方法参数上。例如,你可以标注在实体类字段上,也可以用在Controller方法的参数上。

2. @Retention(RetentionPolicy.RUNTIME):表示该注解在运行时依然可用,这样Spring才能在运行时读取并执行校验逻辑。

3. @Constraint(validatedBy = ValidN1Validator.class):指定该注解由哪个校验器来处理,这里是 ValidN1Validator 类。

4. message():校验失败时返回的默认错误提示信息。

5. groups():分组校验使用,允许你根据不同的业务场景选择性地启用某些校验规则。

6. payload():可选属性,通常用于携带额外元数据,如严重级别等。

二、实现对应的校验器类
import javax.validation.ConstraintValidator;
import javax.validation.ConstraintValidatorContext;public class ValidN1Validator implements ConstraintValidator<ValidN1, Integer> {@Overridepublic boolean isValid(Integer value, ConstraintValidatorContext context) {if(value == null){return true;}if(value >= 0 && value <= 9){return true;}else {return false;}}
}

解析

1. 接口实现:ConstraintValidator<ValidN1, Integer>

  •         第一个泛型参数是注解类型;
  •         第二个泛型参数是要校验的数据类型,这里是Integer。 

2. 方法实现:isValid(Integer value, ConstraintValidatorContext context)

  •         核心校验逻辑,判断传入的值是否符合要求。
三、在实体类中添加注解
public class User {private String name;@ValidN1private Integer sex;
}
四、统一返回错误信息(可选)

为了统一返回错误信息,我们可以使用 @RestControllerAdvice 来捕获校验异常。

@RestControllerAdvice
@Slf4j
public class ValidationExceptionHandler {@ExceptionHandler(MethodArgumentNotValidException.class)public ResponseEntity<RequestDto> handleValidationExceptions(MethodArgumentNotValidException ex) {BindingResult result = ex.getBindingResult();List<String> errors = result.getAllErrors().stream().map(ObjectError::getDefaultMessage).collect(Collectors.toList());RequestDto dto = new RequestDto();dto.setCode(-1);dto.setMessage("参数校验失败:" + errors);return ResponseEntity.badRequest().body(dto);}
}

这样当用户传入非法参数时,系统会返回类似如下格式的响应:

{"code": -1,"message": "参数校验失败:[时间戳格式错误]"
}

http://www.xdnf.cn/news/9722.html

相关文章:

  • SQL输出20个9
  • 商旅平台排名:十大商旅服务平台解析
  • YOLO-UniOW概述 论文
  • Docker 前端镜像容器部署指南
  • 创建型设计模式之Prototype(原型)
  • c/c++的opencv图像金字塔缩放
  • 【代码训练营Day01】数组part1
  • Linux进程间通信----管道
  • 人员睡岗检测算法AI智能分析网关V4打造工业/安防/交通等多场景应用方案
  • VMware安装Ubuntu实战分享大纲
  • Apifox 5 月产品更新|数据模型支持查看「引用资源」、调试 AI 接口可实时预览 Markdown、性能优化
  • 蓝牙芯片投影仪遥控器方案
  • 网络出版服务许可证年检
  • MySQL数据库学习笔记
  • openFuyao开源发布,建设多样化算力集群开源软件生态
  • 【大模型】Bert
  • 计算机网络 | 1.1 计算机网络概述思维导图
  • Nginx代理、缓存与Rewrite
  • 使用LSTM进行时间序列分析
  • 流程自动化引擎:让业务自己奔跑
  • C++031(变量的存储类型-auto变量)
  • 塔能空化泵节能方案:工厂能耗精准控制的革新之选
  • 博图SCL基础知识-寻址调用及新建SCL
  • 记一次前端逻辑绕过登录到内网挖掘
  • 计算机内存管理全解析:从基础原理到前沿技术(含分页/分段/置换算法/大页/NVM/CXL等技术详解
  • C++ explicit关键字有什么作用
  • Dify+MCP Server打造禅道AI智能助手
  • LeetCode 136:只出现一次的数字 - 巧用异或运算的极致解法
  • Open3D上可视化Nuscenes 数据集
  • 谷歌浏览器Google Chrome v137.0.7151.41 中文版本版+插件 v1.11.1