
本文介绍了如何利用 Spring Validation 框架,在 Controller 层对 @RequestParam 注解修饰的请求参数进行校验,特别是禁止接收空字符串("")或只包含空白字符的字符串。通过添加 @Validated 注解和相应的校验注解,可以有效防止非法参数进入业务逻辑,提高代码健壮性。
Spring Validation 提供了一套强大的机制来校验请求参数,可以有效避免无效数据进入业务逻辑。对于 @RequestParam 修饰的参数,我们可以通过以下步骤进行校验:
例如,要禁止接收空字符串或只包含空白字符的字符串列表,可以使用 @NotEmpty 和 @NotBlank 注解:
@RestController
@Validated
public class TestController {
@GetMapping("/test")
public List<StatesInfoVO> getTestStates(@RequestParam @NotEmpty List<@NotBlank String> states) {
//...
}
}注解说明:
请求示例与预期结果:
注意事项:
全局异常处理示例:
@ControllerAdvice
public class GlobalExceptionHandler {
@ExceptionHandler(ConstraintViolationException.class)
@ResponseBody
@ResponseStatus(HttpStatus.BAD_REQUEST)
public Map<String, String> handleConstraintViolationException(ConstraintViolationException ex) {
Map<String, String> errors = new HashMap<>();
ex.getConstraintViolations().forEach(violation -> {
errors.put(violation.getPropertyPath().toString(), violation.getMessage());
});
return errors;
}
}总结:
通过使用 Spring Validation 框架,我们可以方便地对 @RequestParam 注解修饰的请求参数进行校验,特别是禁止接收空字符串或只包含空白字符的字符串。这有助于提高代码的健壮性和安全性,防止无效数据进入业务逻辑。结合全局异常处理机制,可以更好地处理校验失败的情况,提升用户体验。
以上就是Spring RequestParam 参数校验:禁止空字符串与空白字符的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号