博客
关于我
JSR303自定义校验注解
阅读量:317 次
发布时间:2019-03-04

本文共 1733 字,大约阅读时间需要 5 分钟。

JSR303自定义校验注解:从零到hero

在数据校验领域,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/

    你可能感兴趣的文章
    Oracle10g下载地址--多平台下的32位和64位
    查看>>
    Oracle10g安装了11g的ODAC后,PL/SQL连接提示TNS:无法解析指定的连接标识符
    查看>>
    Oracle11G基本操作
    查看>>
    Oracle11g服务详细介绍及哪些服务是必须开启的?
    查看>>
    Oracle11g静默安装dbca,netca报错处理--直接跟换操作系统
    查看>>
    oracle12安装软件后安装数据库,然后需要自己配置监听
    查看>>
    Oracle——08PL/SQL简介,基本程序结构和语句
    查看>>
    Oracle——distinct的用法
    查看>>
    Oracle、MySQL、SQL Server架构大对比
    查看>>
    oracle下的OVER(PARTITION BY)函数介绍
    查看>>
    Oracle中DATE数据相减问题
    查看>>
    Oracle中merge into的使用
    查看>>
    oracle中sql查询上月、本月、上周、本周、昨天、今天的数据!
    查看>>
    oracle中sql的case语句运用--根据不同条件去排序!
    查看>>
    Oracle中Transate函数的使用
    查看>>
    oracle中关于日期问题的汇总!
    查看>>
    Oracle中常用的语句
    查看>>
    Oracle中序列的操作以及使用前对序列的初始化
    查看>>
    oracle中新建用户和赋予权限
    查看>>
    Oracle中的NVL,NVL2,NULLIF以及COALESCE函数使用
    查看>>