博客
关于我
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/

    你可能感兴趣的文章
    oracle数据库 添加定时器
    查看>>
    Oracle数据库ORA-01555解决含clob和blob字段表报错快照过旧问题
    查看>>
    ubuntu24 finalshell 无法连接ubuntu服务器, 客户端无法连接ubuntu, 无法远程连接ubuntu。
    查看>>
    Oracle数据库入门——初级系列教程
    查看>>
    oracle数据库包package小例子
    查看>>
    UBUNTU 添加删除用户
    查看>>
    Oracle数据库备份与还原
    查看>>
    Ubuntu Seata开机自启动服务
    查看>>
    uart 驱动架构
    查看>>
    Oracle数据库学习(三)
    查看>>
    Oracle数据库安装成功后,忘记解锁账户和设置密码
    查看>>
    TypeError: create_purple() 接受 0 个位置参数,但给出了 2 个
    查看>>
    Oracle数据库异常--- oracle_10g_登录em后,提示java.lang.Exception_Exception_in_sending_Request__null或Connection
    查看>>
    Oracle数据库异常---OracleDBConsoleorcl无法启动
    查看>>
    oracle数据库异常---SP2-1503: 无法初始化 Oracle 调用界面 SP2-1503: 无法初始化 Oracle 问题的解决办法
    查看>>
    Oracle数据库性能调优
    查看>>
    oracle数据库核心笔记
    查看>>
    oracle数据库笔记---oracleweb视图使用流程,及plsql安装
    查看>>
    oracle数据库笔记---pl/sql的基础使用方法
    查看>>
    Transformer 架构解释
    查看>>