我跟着本教程创建自定义的验证: http://codetutr.com/2013/05/29/custom-spring-mvc-validation-annotations/定制验证控制器上的方法
而且根据这一条,有可能验证请求aguments与JSR-303的验证注解: https://raymondhlee.wordpress.com/2015/08/29/validating-spring-mvc-request-mapping-method-parameters/
我的定制ConstraintValidator从不被调用。这里是我的代码:
控制器:
@RestController
@RequestMapping(value = "/json")
@Validated
public class JsonResource {
@RequestMapping(method = POST, consumes=APPLICATION_JSON_VALUE"))
public void postJson(@SafeHtml @RequestBody JsonNode jsonQuery){
// post a foo
}
}
SafeHtml注释:
@Documented
@Constraint(validatedBy = {SafeHtmlJsonValidator.class})
@Target({ElementType.PARAMETER, ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
public @interface SafeHtml {
String message() default "{SafeHtml}";
Class<?>[] groups() default {};
Class<? extends Payload>[] payload() default {};
}
定制ConstraintValidator:
@Component
public class SafeHtmlJsonValidator implements ConstraintValidator<SafeHtml, JsonNode> {
@Override
public void initialize(SafeHtml constraintAnnotation) {}
@Override
public boolean isValid(JsonNode value, ConstraintValidatorContext context) {
// validate my JSON
return true;
}
}
的问题是,SafeHtmlJsonValidator.isValid()
永远不会调用。
与Spring 4.2.6.RELEASE
不知道它是否相关,作者在帖子中创建了一个Subscriber.java,其中包含year.clss引用,但是您正在使用@SafeHtml权限Json post请求方法的参数。 – Zeus