java – JSR – 使用Spring Boot对Spring @RestController进行349 bean验证

前端之家收集整理的这篇文章主要介绍了java – JSR – 使用Spring Boot对Spring @RestController进行349 bean验证前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我使用的是 Spring Boot 1.5.2.RELEASE,并且无法为@RequestParam&组合使用JSR-349(bean验证1.1).方法本身的@PathVariable.

对于POST请求,如果method参数是Java POJO,则使用@Valid注释该参数工作正常但注释@RequestParam& @PathVariable与@NotEmpty,@ Email无法正常工作.

我有Spring的@Validated注释控制器类

关于SO有很多问题,我在this answer评论说它不适用于我.

Spring Boot包括 – validation-api-1.1.0.Final.jar和hibernate-validator-5.3.4.Final.jar.

我错过了什么吗?

示例代码,

  1. @RequestMapping(method = RequestMethod.GET,value = "/testValidated",consumes = MediaType.APPLICATION_JSON_VALUE,produces = MediaType.APPLICATION_JSON_VALUE)
  2. public ResponseBean<String> testValidated(@Email @NotEmpty @RequestParam("email") String email) {
  3. ResponseBean<String> response = new ResponseBean<>();
  4. response.setResponse(Constants.SUCCESS);
  5. response.setMessage("testValidated");
  6. logger.error("Validator Not called");
  7. return response;
  8. }

当我发送空值或电子邮件地址不完整的电子邮件地址时,永远不会调用下面的处理程序.控制总是在testValidated方法中使用.

  1. @ExceptionHandler(ConstraintViolationException.class)
  2. @ResponseBody
  3. @ResponseStatus(HttpStatus.BAD_REQUEST)
  4. public ResponseBean handle(ConstraintViolationException exception) {
  5.  
  6. StringBuilder messages = new StringBuilder();
  7. ResponseBean response = new ResponseBean();
  8.  
  9. exception.getConstraintViolations().forEach(entry -> messages.append(entry.getMessage() + "\n"));
  10.  
  11. response.setResponse(Constants.FAILURE);
  12. response.setErrorcode(Constants.ERROR_CODE_BAD_REQUEST);
  13. response.setMessage(messages.toString());
  14. return response;
  15. }

ResponseBean< T>是我的应用程序特定类.

解决方法

经过两天以上的失败后我才问过这个问题&审判.由于围绕Spring Validations和JSR验证的混淆,Spring如何调用JSR验证器,JSR标准和JS的变化,有很多令人困惑的答案.支持的验证类型.

最后,this article帮了很多忙.

我分两步解决了问题,

1.在我的配置中添加了以下bean – 没有这些bean,没有任何作用.

  1. @Bean
  2. public MethodValidationPostProcessor methodValidationPostProcessor() {
  3. MethodValidationPostProcessor mvProcessor = new MethodValidationPostProcessor();
  4. mvProcessor.setValidator(validator());
  5. return mvProcessor;
  6. }
  7.  
  8. @Bean
  9. public LocalValidatorfactorybean validator() {
  10. LocalValidatorfactorybean validator = new LocalValidatorfactorybean();
  11. validator.setProviderClass(HibernateValidator.class);
  12. validator.afterPropertiesSet();
  13. return validator;
  14. }

2.在我的控制器上放置Spring的@Validated注释,如下所示,

  1. @RestController
  2. @RequestMapping("/...")
  3. @Validated
  4. public class MyRestController {
  5. }

验证是 – org.springframework.validation.annotation.Validated

此设置不影响同一控制器中@RequestBody验证的@Valid注释,并且这些注释继续按原样运行.

所以现在,我可以触发MyRestController类中的方法,如下所示的验证,produces = MediaType.APPLICATION_JSON_VALUE) public ResponseBean<String> testValidated( @Email(message="email RequestParam is not a valid email address") @NotEmpty(message="email RequestParam is empty") @RequestParam("email") String email) { ResponseBean<String> response = new ResponseBean<>(); .... return response; }

我必须在异常处理程序中为异常添加另一个处理程序 – ConstraintViolationException,因为@Validated抛出此异常,而@Valid抛出MethodArgumentNotValidException

猜你在找的Java相关文章