本文介绍了如何利用 Spring Validation 框架,在 Controller 层对 @RequestParam 注解修饰的请求参数进行校验,特别是禁止接收空字符串("")或只包含空白字符的字符串。通过添加 @Validated 注解和相应的校验注解,可以有效防止非法参数进入业务逻辑,提高代码健壮性。
Spring Validation 提供了一套强大的机制来校验请求参数,可以有效避免无效数据进入业务逻辑。对于 @RequestParam 修饰的参数,我们可以通过以下步骤进行校验:
例如,要禁止接收空字符串或只包含空白字符的字符串列表,可以使用 @NotEmpty 和 @NotBlank 注解:
@RestController
@Validated
public class TestController {
@GetMapping("/test")
public List getTestStates(@RequestParam @NotEmpty List<@NotBlank String> states) {
//...
}
} 注解说明:
请求示例与预期结果:
。注意事项:
全局异常处理示例:
@ControllerAdvice
public class GlobalExceptionHandler {
@ExceptionHandler(ConstraintViolationException.class)
@ResponseBody
@ResponseStatus(HttpStatus.BAD_REQUEST)
public Map handleConstraintViolationException(ConstraintViolationException ex) {
Map errors = new HashMap<>();
ex.getConstraintViolations().forEach(violation -> {
errors.put(violation.getPropertyPath().toString(), violation.getMessage());
});
return errors;
}
} 总结:
通过使用 Spring Validation 框架,我们可以方便地对 @RequestParam 注解修饰的请求参数进行校验,特别是禁止接收空字符串或只包含空白字符的字符串。这有助于提高代码的健壮性和安全性,防止无效数据进入业务逻辑。结合全局异常处理机制,可以更好地处理校验失败的情况,提升用户体验。