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

Spring Boot常用的参数验证技巧和使用方法

简介

Spring Boot是一个使用Java编写的开源框架,用于快速构建基于Spring的应用程序。在实际开发中,经常需要对输入参数进行验证,以确保数据的完整性和准确性。Spring Boot提供了多种方式来进行参数验证,并且可以很方便地集成到应用程序中。

1. 使用JSR-303注解进行参数验证

JSR-303是Java Validation API的规范之一,它定义了一套用于参数验证的注解。Spring Boot支持使用这些注解来验证方法参数、请求参数和实体类字段等。

@RestController
public class UserController {@PostMapping("/user")public ResponseEntity<String> createUser(@Valid @RequestBody UserRequest request) {// 处理请求return ResponseEntity.ok("User created successfully");}
}

在上面的例子中,@Valid注解用于标记需要验证的参数,@RequestBody注解用于指定该参数为请求体。而UserRequest则是一个自定义的实体类,使用了JSR-303注解来验证字段。

public class UserRequest {@NotBlank(message = "用户名不能为空")private String username;@Size(min = 6, max = 12, message = "密码长度必须在6到12个字符之间")private String password;// getter 和 setter 方法省略
}

UserRequest类中,我们使用了@NotBlank注解来验证username字段不能为空,使用了@Size注解来验证password字段的长度在6到12个字符之间。当参数验证失败时,框架会自动抛出MethodArgumentNotValidException异常,并返回相应的错误信息。

2. 使用自定义验证器

除了使用JSR-303注解外,你还可以编写自己的参数验证器。这对于一些特殊的验证需求,或者需要复杂逻辑的验证场景非常有用。

@Component
public class AgeValidator implements ConstraintValidator<ValidAge, Integer> {@Overridepublic boolean isValid(Integer age, ConstraintValidatorContext context) {// 实现自定义的验证逻辑return age >= 18 && age <= 60;}
}

首先,我们需要编写一个实现了ConstraintValidator接口的验证器类。在上面的例子中,我们定义了一个AgeValidator类,用于验证年龄是否在合法范围内(18到60岁)。然后,我们需要在需要验证的地方使用@ValidAge注解来标记需要验证的参数。

@RestController
public class UserController {@PostMapping("/user")public ResponseEntity<String> createUser(@ValidAge @RequestParam("age") Integer age) {// 处理请求return ResponseEntity.ok("User created successfully");}
}

在上述代码中,我们使用了@ValidAge注解来验证age参数的合法性。当参数验证失败时,框架会自动抛出MethodArgumentNotValidException异常,并返回相应的错误信息。

3. 自定义验证错误处理

除了使用框架提供的默认错误处理方式外,你还可以定制化错误处理。可以通过编写全局异常处理器来对参数验证失败时的异常进行捕获和处理。

@ControllerAdvice
public class GlobalExceptionHandler {@ExceptionHandler(MethodArgumentNotValidException.class)public ResponseEntity<String> handleMethodArgumentNotValid(MethodArgumentNotValidException ex) {BindingResult result = ex.getBindingResult();List<ObjectError> errors = result.getAllErrors();StringBuilder errorMessage = new StringBuilder();for (ObjectError error : errors) {errorMessage.append(error.getDefaultMessage()).append("; ");}return ResponseEntity.badRequest().body(errorMessage.toString());}
}

在上述代码中,我们使用@ControllerAdvice注解将该类声明为全局异常处理器,并使用@ExceptionHandler注解来指定处理MethodArgumentNotValidException异常。当参数验证失败时,会自动进入到这个处理方法中,我们可以从异常对象中获取详细的错误信息并进行处理。

结论

Spring Boot提供了多种灵活且强大的参数验证技巧和使用方法,包括使用JSR-303注解进行参数验证、自定义验证器以及自定义验证错误处理等。通过合理地运用这些技巧,我们可以保证应用程序接收到正确且完整的参数输入,提高系统的稳定性和安全性。

http://www.lryc.cn/news/164050.html

相关文章:

  • 手机+卫星的科技狂想
  • 便捷查询中通快递,详细物流信息轻松获取
  • ARM接口编程—Interrupt(exynos 4412平台)
  • 适用于Linux的Windows子系统(PHP搭建lmap、redis、swoole环境)
  • Vue3+Ts+Vite项目(第十二篇)——echarts安装与使用,vue3项目echarts组件封装
  • hive location更新hive元数据表详解
  • 【SpringBoot】统一功能处理
  • 分布式数据库-架构真题(二十六)
  • MyWebServer开发日记-socket
  • 图书管理信息系统分析与设计
  • Charles基础使用指南
  • Android12之/proc/pid/status参数含义(一百六十五)
  • UMA 2 - Unity Multipurpose Avatar☀️三.给UMA设置默认服饰Recipes
  • uniapp-小程序登录授权框
  • Unity 性能优化Shader分析处理函数:ShaderUtil.GetShaderGlobalKeywords用法
  • 第一百四十一回 如何添加程序启动页
  • 从零开始的PICO教程(4)--- UI界面绘制与响应事件
  • IntelliJ IDEA 远程调试 Tomcat
  • 谷粒商城----认证服务
  • Mediasoup源码介绍
  • GIS入门,WKT格式详解
  • Qt之postEvent
  • 1976~2020年青藏高原典型冰川及冰湖遥感监测数据集
  • 时序预测 | MATLAB实现LSSVM最小二乘支持向量机时间序列预测未来
  • windows10 使用WSL2安装原生docker
  • jupylab pandas按条件批量处理xls数据
  • RJ45水晶头网线顺序出错排查
  • 【洛谷 P1115】最大子段和 题解(贪心算法)
  • uni-app--》基于小程序开发的电商平台项目实战(一)
  • 入门人工智能 —— 学习一门编程语言 python 基础代码编写和运算符介绍(1)