spring boot接口参数校验:get与post请求差异及统一处理方案
本文探讨Spring Boot中GET和POST请求参数校验的差异,并提供一种统一处理校验结果的方案。
问题描述:
在Spring Boot v2.7.14-snapshot版本中,使用spring-boot-starter-validation依赖。POST请求使用@RequestBody @Valid进行参数校验,能有效捕获MethodArgumentNotValidException并返回类似“校验失败: parentId:不能为null”的错误信息。然而,GET请求使用@RequestParam long feedId,即使添加@Validated注解和@NotNull注解,也无法正常校验,而是抛出MissingServletRequestParameterException异常,提示“required request parameter 'feedId' for method parameter type long is not present”。 目标是使GET请求的校验结果与POST请求一致,返回类似“校验失败: feedId:不能为null”的错误信息。
解决方案:
为了统一GET和POST请求的参数校验及错误处理,建议采用以下方法:
- 封装GET请求参数: 将GET请求参数封装到一个DTO对象中。例如,创建一个ApiGetRequest类:
public class ApiGetRequest {
@NotNull
private Long feedId;
// getters and setters
}
修改GET请求的Controller方法:
@GetMapping("/api")
public String apiGet(@Valid ApiGetRequest request) {
// ...
}
- 自定义全局异常处理器: 创建一个全局异常处理器,统一处理MissingServletRequestParameterException异常,并返回自定义的错误信息格式:
@ControllerAdvice
public class GlobalExceptionHandler {
@ExceptionHandler(MissingServletRequestParameterException.class)
@ResponseBody
public String handleMissingParams(MissingServletRequestParameterException ex) {
String paramName = ex.getParameterName();
return String.format("校验失败: %s:不能为null", paramName);
}
// 可以在此处添加其他异常处理方法,例如MethodArgumentNotValidException的处理
}
通过以上步骤,GET请求的参数校验将与POST请求保持一致,并返回统一格式的错误信息。@Valid注解结合DTO对象确保了GET请求参数的有效校验,而自定义的全局异常处理器则负责统一异常处理和错误信息格式化。
通过这种方式,可以有效解决Spring Boot中GET和POST请求参数校验不一致的问题,并提供更一致、更友好的用户体验。
以上就是Spring Boot中GET和POST请求参数校验为何不同,如何统一处理校验结果?的详细内容,更多请关注知识资源分享宝库其它相关文章!
版权声明
本站内容来源于互联网搬运,
仅限用于小范围内传播学习,请在下载后24小时内删除,
如果有侵权内容、不妥之处,请第一时间联系我们删除。敬请谅解!
E-mail:dpw1001@163.com
发表评论