本文共 1733 字,大约阅读时间需要 5 分钟。
在数据校验领域,JSR303自定义校验注解是开发者不可或缺的利器。传统的正则表达式虽然强大,但在某些复杂场景下往往显得力不从心。因此,通过自定义校验注解,我们可以更灵活地满足业务需求。
当普通的正则校验无法覆盖业务需求时,自定义校验注解就显得尤为重要。一个典型的例子是对特定字段的取值范围进行严格控制。例如,showStatus字段可能只允许取值0或1,而不是传统的正则表达式无法精确约束这种情况。
我们需要创建一个类似于@NotNull的自定义注解。参考标准注解的实现,我们可以定义一个新的注解接口,并配置相关属性。
@Target(ElementType.METHOD, ElementType.FIELD, ElementType.ANNOTATION_TYPE, ElementType.CONSTRUCTOR, ElementType.PARAMETER)@Retention(RetentionPolicy.RUNTIME)@Documented@Constraint(validatedBy = {ListValueConstraintValidator.class})public @interface ListValue { String message() default "{com.atstudying.common.valid.ListValue.message}"; Class [] groups() default {}; Class [] payload() default {}; int[] vals() default {};} 这个注解接口配置了几个关键属性:
message():默认的错误信息,建议在ValidationMessages.properties中定义。groups():用于分组校验,可以根据需求扩展。payload():可选的额外载荷,可以根据具体需求使用。vals():指定允许的取值数组。接下来,我们需要实现一个对应的校验器类,用于验证注解的约束条件。
public class ListValueConstraintValidator implements ConstraintValidator{ private Set allowedValues = new HashSet<>(); @Override public void initialize(ListValue constraintAnnotation) { int[] vals = constraintAnnotation.vals(); for (int val : vals) { allowedValues.add(val); } } @Override public boolean isValid(Integer value, ConstraintValidatorContext context) { return allowedValues.contains(value); }}
这个校验器类的主要职责是:
isValid方法中,检查输入值是否在允许范围内。在注解接口中,我们需要指定使用哪个校验器来执行约束检查。
@Constraint(validatedBy = {ListValueConstraintValidator.class}) 通过这种方式,我们就完成了校验器与注解的关联。
通过以上步骤,我们成功创建了一个自定义的校验注解,并实现了对特定字段取值范围的校验。这种方式不仅提升了校验逻辑的可维护性,还为业务需求的个性化配置提供了灵活的支持。
转载地址:http://zzhq.baihongyu.com/