如果我们定义一个类级验证注释,例如比较字段并且具有ConstraintValidator
的类注释:
public class ComparisonValidator implements ConstraintValidator<ValueMatches, Object>
{
private String[] fields;
@Override
public void initialize(final ValueMatches constraintAnnotation) {
fields = constraintAnnotation.fields();
}
@Override
public boolean isValid(final Object value, final ConstraintValidatorContext context) {
if (fields.length == 0) {
return true;
}
final BeanWrapperImpl beanWrapper = new BeanWrapperImpl(value);
final Object comparisonValue = beanWrapper.getPropertyValue(fields[0]);
for (int i = 1; i < fields.length; i++) {
final Object fieldValue = beanWrapper.getPropertyValue(fields[i]);
if (!comparisonValue.equals(fieldValue)) {
return false;
}
}
return true;
}
}
我们很好地产生了一个全局验证错误,可以通过Thymeleaf使用:
${#fields.errors('global')}
现在,我如何识别该错误并了解它是具体的比较错误?我的意思是,毕竟我们收到了全局错误的消息,或者我错了吗?
答案 0 :(得分:4)
该死的,Spring文档! 这很简单,但不太明白。
@Override
public boolean isValid(final Object value, final ConstraintValidatorContext context) {
if (fields.length > 0) {
final BeanWrapperImpl beanWrapper = new BeanWrapperImpl(value);
final Object comparisonValue = beanWrapper.getPropertyValue(fields[0]);
for (int i = 1; i < fields.length; i++) {
if (!comparisonValue.equals(beanWrapper.getPropertyValue(fields[i]))) {
context.disableDefaultConstraintViolation();
context.buildConstraintViolationWithTemplate(errorMessage).addPropertyNode(fields[0]).addConstraintViolation();
return false;
}
}
}
return true;
}
方法disableDefaultConstraintViolation()
通过使用注释本身告诉ConstrainValidatorContext
不生成约束违规对象。
然后,您可以通过buildConstraintViolationWithTemplate()
方法生成自定义约束违规。