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

活到老学到老-Spring参数校验注解Validated /Valid

通过 @Validated 和 @Valid可以对请求的进行参数校验。

1.核心对比:

特性@Valid (JSR-303)@Validated (Spring)
来源Java标准规范Spring框架扩展
分组校验不支持支持(通过groups属性)
嵌套路径自动处理级联校验需配合@Valid生效
应用范围方法参数、属性、返回值类、方法、参数
List校验需放在集合声明处需配合@Valid生效

2.基础使用示例

 2.1 单对象校验

public class UserDTO {@NotBlank(message = "用户名不能为空")private String username;@Email(message = "邮箱格式错误")private String email;
}// 使用@Valid
@PostMapping("/users")
public Result createUser(@RequestBody @Valid UserDTO user) {// ...
}// 使用@Validated
@RestController
@Validated // 类级别启用校验
public class UserController {@PostMapping("/users")public Result createUser(@RequestBody @Validated UserDTO user) {// ...}
}

3. 级联属性校验

3.1 嵌套对象校验
public class OrderDTO {@NotNullprivate Long orderId;@Valid // 关键注解,启用嵌套校验private UserDTO user;
}// 测试
@PostMapping("/orders")
public Result createOrder(@RequestBody @Valid OrderDTO order) {// 会自动校验order.user里的约束
}
3.2 集合元素校验
public class BatchRequest {@Size(min = 1, max = 10)private List<@Valid UserDTO> users; // 校验每个元素
}@PostMapping("/batch")
public Result batchCreate(@RequestBody @Valid BatchRequest request) {// 会校验list内每个UserDTO
}

4. 分组校验(仅@Validated支持)

4.1 定义校验分组
public interface CreateCheck {}
public interface UpdateCheck {}public class ProductDTO {@Null(groups = CreateCheck.class) // 创建时ID必须为空@NotNull(groups = UpdateCheck.class) // 更新时ID不能为空private Long id;@NotBlank(groups = {CreateCheck.class, UpdateCheck.class})private String name;
}
4.2 使用分组
@PostMapping("/products")
public Result create(@RequestBody @Validated(CreateCheck.class) ProductDTO product) {// 仅触发CreateCheck组的校验
}@PutMapping("/products/{id}")
public Result update(@PathVariable Long id, @RequestBody @Validated(UpdateCheck.class) ProductDTO product) {// 仅触发UpdateCheck组的校验
}

5.统一异常处理

@RestControllerAdvice
public class GlobalExceptionHandler {// 处理@Validated和@Valid抛出的异常@ExceptionHandler(MethodArgumentNotValidException.class)public Result handleValidException(MethodArgumentNotValidException e) {List<String> errors = e.getBindingResult().getFieldErrors().stream().map(error -> error.getField() + ": " + error.getDefaultMessage()).collect(Collectors.toList());return Result.fail(400, "参数错误", errors);}
}

6.最佳实现

6.1 混合使用
类/方法级用 @Validated参数/属性级用 @Valid
6.2 性能优化
// 避免在循环中校验
@Validated
@Service
public class UserService {public void batchProcess(@Valid List<UserDTO> users) {// 批量处理}
}
6.3 自定义校验
@Target({FIELD})
@Retention(RUNTIME)
@Constraint(validatedBy = PhoneValidator.class)
public @interface Phone {String message() default "手机号格式错误";Class<?>[] groups() default {};Class<? extends Payload>[] payload() default {};
}
6.4 复杂场景
// 级联校验+集合校验
public class DepartmentDTO {@Validprivate List<@Valid EmployeeDTO> employees;@Validprivate AddressDTO location;
}

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

相关文章:

  • 实战:基于Pangolin Scrape API,如何高效稳定采集亚马逊BSR数据并破解反爬虫?
  • Nuxt.js一个基于 Vue.js 的通用应用框架
  • 使用引用的原因 和 运算符重载的必要性
  • Ubuntu20.04安装ROS Neotic
  • AI应用交付厂商F5打造六大解决方案,助用户应对复杂挑战
  • NX750HSA20美光固态闪存HSA36NC027
  • LLM驱动的未来软件工程范式与架构策略
  • 鸿蒙开发——7.ArkUI进阶:@BuilderParam装饰器的核心用法与实战解析
  • 算法题(151):保卫花园
  • Vue video播放视频流
  • Vue 3 响应式 Ref 全解析:从基础到高阶应用
  • 监控易一体化运维:采集集群管理,构建稳健运维基石
  • Linux | 开机自启动设置多场景实现
  • 在QT中栅格布局里套非栅格布局的布局会出现父布局缩放子布局不跟随的问题
  • 深入解析FramePack:高效视频帧打包技术原理与实践
  • 前端单点登录
  • DNA与蛋白相互作用检测技术ChIP-qPCR
  • 系统思考:团队策略辅导
  • 软考软件评测师——基于风险的测试技术
  • 破解 PCB 制造四大痛点:MOM 系统构建智能工厂新范式
  • 【Java微服务组件】异步通信P1—消息队列基本概念
  • RocketMQ 顺序消息实现原理详解
  • 小米便签源码部署流程
  • 前端mjs和js文件区别,mjs和cjs区别---.es.js和.mjs的区别
  • Oracle Apps R12——报表入门:如何定义一个Concurrent Program(请求)
  • 【Auto-dl ssh隧道,TensorBoard】
  • 矩阵的秩(Rank)
  • 【Vue篇】组件的武林绝学:状态风暴下的乾坤挪移术
  • 考研系列-408真题计算机组成原理篇(2015-2019)
  • Linux中的 I/O 复用机制 select