我对JSR-303的@Valid
注释有疑问。 annotation适用于普通列表或集合,但我正在尝试验证包含列表的地图,即
@Valid
HashMap<String, ArrayList<Object1>> map;
在这种情况下,Object1
类的实例未经过验证。是否有一种方便的方法来递归执行此操作,而无需迭代每个对象并手动验证它?
答案 0 :(得分:13)
当地图值本身就是列表时,规范没有指定验证行为。
验证迭代器提供的每个对象。对于Map,值 每个Map.Entry都经过验证(密钥未经过验证)。
由于您的案例中的值是一个没有@Valid注释的列表,因此不会对其进行处理。要解决这个问题,您可以:
将包含的列表包装在另一个bean中,强制将注释处理到列表中。
public class ListHolder<T extends Iterable> {
@Valid
public T wrappedList;
}
或者您可以编写custom validator来处理复杂的地图。像这样:
@Target({ METHOD, FIELD, ANNOTATION_TYPE })
@Retention(RUNTIME)
@Documented
@Constraint(validatedBy = ValidMapValidator.class)
public @interface ValidMap {
String message() default "valid.map";
Class<?>[] groups() default {};
Class<? extends Payload>[] payload() default {};
}
public class ValidMapValidator implements
ConstraintValidator<ValidMap, Map<?, ?>> {
@Override
public void initialize(final ValidMap annotation) {
return;
}
@Override
public boolean isValid(final Map<?, ?> map,
final ConstraintValidatorContext context) {
if (map == null || map.size() == 0)
return true;
// Iterate each map entry and validate
return true;
}
}