@Constraint实现自定义校验注解

@Constraint 是 Java 中用于定义自定义校验注解的一个元注解。它通常与 Hibernate Validator 或其他基于 JSR 380(Bean Validation 2.0)的校验框架一起使用。通过 @Constraint 注解,你可以创建自己的校验逻辑,并将其应用到实体类的字段上

1. 创建自定义校验注解

首先,定义一个自定义校验注解。假设我们想创建一个注解 @ValidLength,用于校验字符串的最大长度为20位。

import javax.validation.Constraint;
import javax.validation.Payload;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

@Constraint(validatedBy = ValidLengthValidator.class)
@Target({ ElementType.METHOD, ElementType.FIELD, ElementType.ANNOTATION_TYPE, ElementType.PARAMETER })
@Retention(RetentionPolicy.RUNTIME)
public @interface ValidLength {
    String message() default "长度必须在1到20个字符之间";
    Class<?>[] groups() default {};
    Class<? extends Payload>[] payload() default {};
    int min() default 1;
    int max() default 20;
}

2. 创建校验器

接下来,创建一个实现 ConstraintValidator 接口的类,用于实现具体的校验逻辑。

import javax.validation.ConstraintValidator;
import javax.validation.ConstraintValidatorContext;

public class ValidLengthValidator implements ConstraintValidator<ValidLength, String> {

    private int min;
    private int max;

    @Override
    public void initialize(ValidLength constraintAnnotation) {
        this.min = constraintAnnotation.min();
        this.max = constraintAnnotation.max();
    }

    @Override
    public boolean isValid(String value, ConstraintValidatorContext context) {
        if (value == null) {
            return true; // 允许为空
        }
        return value.length() >= min && value.length() <= max;
    }
}

 3. 应用自定义校验注解

在实体类中使用自定义校验注解。

import javax.validation.constraints.NotNull;

public class User {

    @NotNull
    @ValidLength(min = 1, max = 20)
    private String username;

    // Getters and Setters
    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }
}

4. 测试校验

编写一个测试类来验证校验逻辑是否按预期工作。

import javax.validation.Validation;
import javax.validation.Validator;
import javax.validation.ValidatorFactory;
import javax.validation.ConstraintViolation;
import java.util.Set;

public class Main {
    public static void main(String[] args) {
        User user = new User();
        user.setUsername("12345678901234567890"); // 20位,合法

        ValidatorFactory factory = Validation.buildDefaultValidatorFactory();
        Validator validator = factory.getValidator();

        Set<ConstraintViolation<User>> violations = validator.validate(user);
        for (ConstraintViolation<User> violation : violations) {
            System.out.println(violation.getMessage());
        }

        if (violations.isEmpty()) {
            System.out.println("校验通过");
        } else {
            System.out.println("校验失败");
        }
    }
}

输出
运行上述代码后,如果 username 的长度在1到20个字符之间,输出将是:
校验通过
如果 username 的长度超过20个字符或小于1个字符,输出将是:
长度必须在1到20个字符之间
校验失败

总结

  • 自定义校验注解:使用 @Constraint 注解定义自定义校验注解。
  • 校验器:实现 ConstraintValidator 接口,编写具体的校验逻辑。
  • 应用注解:在实体类的字段上使用自定义校验注解。
  • 测试校验:使用 Validator 对象进行校验,并处理校验结果。
### Java自定义注解实现参数校验的功能 在Java开发中,通过自定义注解可以灵活地满足复杂的业务需求。以下是基于提供的引用内容以及标准实践的一个完整示例。 #### 创建自定义注解 首先需要定义一个注解类,并指定其作用范围和生命周期。以下是一个名为`@State`的自定义注解: ```java package com.example.validate; import javax.validation.Constraint; import javax.validation.Payload; import java.lang.annotation.*; @Documented @Target({ElementType.METHOD, ElementType.FIELD, ElementType.PARAMETER}) @Retention(RetentionPolicy.RUNTIME) @Constraint(validatedBy = StateValidator.class) // 验证器类 public @interface State { String value(); // 定义允许的状态值列表 String message() default "Invalid state"; // 默认错误提示信息 Class<?>[] groups() default {}; Class<? extends Payload>[] payload() default {}; } ``` 此部分展示了如何创建一个简单的自定义注解[@State],它能够接收一组合法状态作为输入并提供默认的消息处理机制[^1]。 #### 编写验证逻辑 接着需编写具体的验证逻辑,即实现`javax.validation.ConstraintValidator<A,T>`接口。这里以检查整数类型的字段是否属于预设的一组有效状态为例: ```java package com.example.validate; import javax.validation.ConstraintValidator; import javax.validation.ConstraintValidatorContext; import java.util.Arrays; import java.util.List; public class StateValidator implements ConstraintValidator<State, Integer> { private List<Integer> allowedStates; @Override public void initialize(State constraintAnnotation) { this.allowedStates = Arrays.asList(constraintAnnotation.value().split(",")) .stream() .map(Integer::parseInt) .toList(); } @Override public boolean isValid(Integer value, ConstraintValidatorContext context) { if (value == null || allowedStates.contains(value)) { return true; } return false; } } ``` 上述代码片段实现了对传入数值的合法性判断过程,其中初始化方法负责解析配置好的可接受状态集合;而有效性检测函数则依据当前实例属性决定是否符合预期条件[^2]。 #### 使用自定义注解 最后可以在实体类或者控制器层的方法签名上运用该注解来进行约束声明: ```java public class OrderRequest { @State("0,1") // 只能取值为0或1 private int orderStatus; // Getter and Setter omitted... } // 或者应用于Controller中的请求参数 @RestController @RequestMapping("/orders") public class OrderController { @PostMapping("/{id}") public ResponseEntity<String> updateOrder(@PathVariable Long id, @RequestBody @Valid OrderRequest request){ // Business logic here ... return ResponseEntity.ok("Success"); } } ``` 以上例子说明了怎样利用Spring框架下的自动注入特性配合Hibernate Validator完成基本的数据完整性检验工作流程^。 --- 问题
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值