Validation实现自定义校验

首先,我们先看一下valid自带的长度校验Length的源码,我将下面源码的注解作出一定的解释

// 指示注解应该记录在生成的Javadoc中,确保自定义注解在生成的文档中可见,便于了解其功能和用途
@Documented
// 指定用于验证该注解的验证器类,之后我们把自定义的校验器类名写在这里即可
@Constraint(
    validatedBy = {}
)
// 指定注解可以应用的Java元素类型
@Target({ElementType.METHOD, ElementType.FIELD, ElementType.ANNOTATION_TYPE, ElementType.CONSTRUCTOR, ElementType.PARAMETER, ElementType.TYPE_USE})
// 指定注解的保留策略,此处为“运行时保留”,还有“编译时保留”和“只在源码中存在”
@Retention(RetentionPolicy.RUNTIME)
使注解可以在同一个元素上多次应用
@Repeatable(List.class)
public @interface Length {
    int min() default 0;

    int max() default Integer.MAX_VALUE;

    String message() default "{org.hibernate.validator.constraints.Length.message}";

    Class<?>[] groups() default {};

    Class<? extends Payload>[] payload() default {};

    @Target({ElementType.METHOD, ElementType.FIELD, ElementType.ANNOTATION_TYPE, ElementType.CONSTRUCTOR, ElementType.PARAMETER, ElementType.TYPE_USE})
    @Retention(RetentionPolicy.RUNTIME)
    @Documented
    public @interface List {
        Length[] value();
    }
}

上面代码所提到的@Repeatable注解大致作用如下:

public class Example {
    @Valid("check1")
    @Valid("check2")
    private String field;
}

看完validation自带的长度校验之后,我们自己实现一个字符串开头字符为'a'的校验:

  1. 首先,先自定义一个校验注解
    @Documented
    // 这个里面的StartWithAValidation.class就是我们第二步将要写的自定义校验器
    @Constraint(
            validatedBy = StartWithAValidation.class
    )
    @Target({ElementType.METHOD, ElementType.FIELD, ElementType.ANNOTATION_TYPE, ElementType.CONSTRUCTOR, ElementType.PARAMETER, ElementType.TYPE_USE})
    @Retention(RetentionPolicy.RUNTIME)
    @Repeatable(StartWithA.List.class)
    public @interface StartWithA {
    
        String message() default "不是以‘a’开头的";
    
        Class<?>[] groups() default {};
    
        Class<? extends Payload>[] payload() default {};
    
    
        @Target({ElementType.METHOD, ElementType.FIELD, ElementType.ANNOTATION_TYPE, ElementType.CONSTRUCTOR, ElementType.PARAMETER, ElementType.TYPE_USE})
        @Retention(RetentionPolicy.RUNTIME)
        @Documented
        public @interface List {
            StartWithA[] value();
        }
    }
  2.  我们开始实现一个自定义校验器类,这个校验器类需要实现ConstraintValidator接口,然后实现接口的isValid方法,代码如下:
    public class StartWithAValidation implements ConstraintValidator<StartWithA,String> {
    
        @Override
        public boolean isValid(String s, ConstraintValidatorContext constraintValidatorContext) {
            // 这里面写一些校验规则
            if(s.charAt(0) == 'a'){
                return true;
            }
            return false;
        }
    }
  3. 之后在我们所需要校验的实体类里面添加校验注解:
        @StartWithA
        private String functions;
  4. 最后,在接受校验数据的接口参数部分添加@Valided注解,因为我的functions字段在TaskReqVo中,所以在这个接口参数中添加注解即可

    public ResponseData save(@RequestBody @Validated TaskReqVo taskReqVo){
            return ResponseData.success(taskService.saveTask(taskReqVo));
        }
  5. 如果格式不对则会在后端日志出现以下提醒

以上便是自定义校验器的实现步骤,欢迎大家提出自己的见解!!!

  • 12
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot 提供了一种基于注解的方式来实现校验,即使用 `javax.validation` 标准规范中的注解来实现校验。如果需要自定义校验规则,可以按照以下步骤进行: 1. 创建自定义注解 ```java @Target({ElementType.FIELD}) @Retention(RetentionPolicy.RUNTIME) @Constraint(validatedBy = MyValidator.class) public @interface MyValidation { String message() default "Invalid field"; Class<?>[] groups() default {}; Class<? extends Payload>[] payload() default {}; } ``` 2. 创建自定义校验器 ```java public class MyValidator implements ConstraintValidator<MyValidation, String> { @Override public void initialize(MyValidation constraintAnnotation) { // 初始化 } @Override public boolean isValid(String value, ConstraintValidatorContext context) { // 自定义校验逻辑 return value != null && value.startsWith("prefix"); } } ``` 3. 在需要校验的字段上添加自定义注解 ```java public class MyEntity { @MyValidation private String myField; // getter/setter } ``` 4. 在 Controller 中使用 `@Validated` 注解进行校验 ```java @RestController @RequestMapping("/my-entity") @Validated public class MyController { @PostMapping public MyEntity create(@RequestBody @Valid MyEntity entity) { // 创建实体 } } ``` 在上面的示例中,`MyValidation` 注解和 `MyValidator` 校验实现了一个自定义校验规则,用于判断字符串是否以 "prefix" 开头。在 `MyEntity` 实体类中,使用了 `@MyValidation` 注解来标注需要校验的字段。在 `MyController` 中,使用了 `@Validated` 注解来开启校验,并在 `create()` 方法中使用 `@RequestBody @Valid` 注解来对请求体进行校验。 以上就是使用 Spring Boot 自定义校验规则的步骤。需要注意的是,自定义校验注解需要使用 `@Constraint` 注解进行标注,并指定校验器的实现类。校验器需要实现 `ConstraintValidator` 接口,并指定校验注解和校验字段的类型。在校验逻辑中,可以使用 `ConstraintValidatorContext` 对象来进行错误信息的设置。在 Controller 中,需要使用 `@Validated` 注解开启校验,并在需要校验的参数上使用 `@Valid` 注解。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值