1

我已经用方法实现了控制器:

public Page<EventDto> search(@ModelAttribute @Valid EventsCriteria criteria){...}

有用。EventsCriteria本身没有特殊的单独验证器,因为它具有内部注释检查器,例如@NotNull @NotEmpty. 现在情况发生了变化,只有这个验证器是不够的。所以我添加并注册了相应的服务来验证一些状态。

我希望服务能够像以前一样验证其他复合案例和单一验证。但是我的单个内部注释检查器@NotNull @NotEmpty不再起作用。

我是否配置错误或无法同时工作(指定的服务和内部检查器)?

我的验证器示例(正如评论中所要求的那样)

没有什么特别的,如果你知道春天,所以我错过了这部分就像不重要的一样,把你的注意力集中在我的问题上。

@Component
public class EventsCriteriaValidator implements Validator {

    public static final String INVALID_RAGE_PARAMETERS_SPECIFIED = "Invalid rage parameters: please specify " +
            "'from' and 'to' or page 'size";

    @Override
    public boolean supports(Class<?> clazz) {
        return clazz.isAssignableFrom(EventsCriteria.class);
    }

    @Override
    public void validate(Object target, Errors errors) {
        EventsCriteria toValidate = (EventsCriteria) target;
        validateComplexRestriction(toValidate, errors);
    }

    private void validateComplexRestriction(EventsCriteria toValidate, Errors errors) {
        if (toValidate.isRangeEmpty() && toValidate.getSize() == 0) {
            errors.rejectValue(SIZE_FIELD, null, INVALID_RAGE_PARAMETERS_SPECIFIED);
        }
    }

}
4

3 回答 3

1

假设您的 EventsCriteria 包含两个字段,因此在您的 validate 方法中,您可以使用以下方法验证这些字段:ValidationUtils (org.springframework.validation.ValidationUtils)

 @Override
    public void validate(Object target, Errors errors) {
        EventsCriteria eventsCriteria= (EventsCriteria) target;
        ValidationUtils.rejectIfEmpty(errors, "field1", "eventsCriteria.field1.empty");
        ValidationUtils.rejectIfEmpty(errors, "field2", "eventsCriteria.field2.empty");
    }

在你的messages.properties

eventsCriteria.field1.empty = Enter a valid value for field 1.
eventsCriteria.field2.empty = Enter a valid value for field 2.

并在您的配置类中添加此 bean:

 @Bean
   public MessageSource messageSource() {
      ResourceBundleMessageSource source = new ResourceBundleMessageSource();
      source.setBasename("messages");
      return source;
   }
于 2017-12-06T17:00:54.977 回答
0

只需进行Validator扩展LocalValidatorFactoryBean,然后super.validate(target, errors)像这样调用您的验证方法:

@Override
public void validate(Object target, Errors errors) {
   super.validate(target, errors);

   EventsCriteria toValidate = (EventsCriteria) target;
   validateComplexRestriction(toValidate, errors);
}
于 2017-12-06T16:55:57.177 回答
0

编辑:

如果您想要自定义验证和默认验证,您可以使用addValidatorsin initBinder添加自定义验证。这样默认验证不会被删除。

@Controller
public class MyController
{
    @Autowired
    private EventsCriteriaValidator validator;

    @InitBinder
    protected void initBinder(final WebDataBinder binder)
    {
         binder.addValidators(validator);
    }

  public Page<EventDto> search(@ModelAttribute @Valid EventsCriteria   criteria, BindingResult result){

     if (result.hasErrors()) {
        // validation failed

     } else {
        //validation passed   
     }
  }

}
于 2017-12-06T13:31:10.800 回答