1.@Validations 源代码
public @interface Validations {
/**
* Custom Validation rules.
*/
public CustomValidator[] customValidators() default {};
public ConversionErrorFieldValidator[] conversionErrorFields() default {};
public DateRangeFieldValidator[] dateRangeFields() default {};
public EmailValidator[] emails() default {};
public FieldExpressionValidator[] fieldExpressions() default {};
public IntRangeFieldValidator[] intRangeFields() default {};
public RequiredFieldValidator[] requiredFields() default {};
public RequiredStringValidator[] requiredStrings() default {};
public StringLengthFieldValidator[] stringLengthFields() default {};
public UrlValidator[] urls() default {};
public ConditionalVisitorFieldValidator[] conditionalVisitorFields() default {};
public VisitorFieldValidator[] visitorFields() default {};
public RegexFieldValidator[] regexFields() default {};
public ExpressionValidator[] expressions() default {};
}
@Validations主要用于action方法参数的校验,根据源码,可以同时校验日期范围,邮件格式,数值范围,非空字符,字符长度范围等。
2. StringLengthFieldValidator的bug
当需要校验多个参数的字符长度时,只会校验最后一个参数。
3. 对@DoubleRangeFieldValidator不支持
action方法中,如果不使用@Validations注解,则不允许重复使用单个特定的验证。比如,不允许在方法上添加多个@DoubleRangeFieldValidator注解。
但是,在@Validations中却没有一个doubleRangeFields这个参数来让程序员检验多个浮点数的范围!
不过所幸的是,@Validations为我们提供了正则校验,这样就可以弥补上述的两个小问题。