通过谷粒商城项目学习自定义校验器的实现

近日在学习雷神的谷粒商城项目,其中有一个自定义校验实现记录一下学习过程。下面是自定义校验实现的三个过程


提示:以下是本篇文章正文内容,下面案例可供参考

一、编写自定义校验注解

1.假如我们自定义一个校验注解,该注解是判断字段是否为0,1。如果不是0或者1,则校验报错

@ListValue(vals={0,1})
private Integer showStatus;

2.进行自定义注解的创建,注意创建类型Annotation
在这里插入图片描述


3.查看其它自定义注解,发现都有三个元数据

String message() default "{javax.validation.constraints.NotBlank.message}";

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

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

将这三条数据编写进入自定义注解里面


4.因为我们自定义注解还包含vals这个数组,所以我们需要创建一个这样的数据数据

int[] vals() default {};

5.引入相关的注解,观看其他注解,发现基本实现了下面的注解

@Documented
@Constraint(
        validatedBy = {ListValueConstraintValidator.class}//使用哪个注解校验器
)
@Target({ElementType.METHOD, ElementType.FIELD, ElementType.ANNOTATION_TYPE, ElementType.CONSTRUCTOR, ElementType.PARAMETER, ElementType.TYPE_USE})//在那些上面可以使用方法字段
@Retention(RetentionPolicy.RUNTIME)//运行获取

下面是自定义注解整个代码实现

package com.atguigu.common.valid;

import javax.validation.Constraint;
import javax.validation.Payload;
import java.lang.annotation.*;

@Documented
@Constraint(
        validatedBy = {ListValueConstraintValidator.class}
)
@Target({ElementType.METHOD, ElementType.FIELD, ElementType.ANNOTATION_TYPE, ElementType.CONSTRUCTOR, ElementType.PARAMETER, ElementType.TYPE_USE})
@Retention(RetentionPolicy.RUNTIME)
public @interface ListValue {
    String message() default "{com.atguigu.common.valid.ListValue.message}";

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

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

    int[] vals() default {};
}


二、自定义注解的校验器

1.在自定义注解里面,有一个引用哪个校验器的字段validatedBy,点进去看一下,发现实现了这个接口:ConstraintValidator在这里插入图片描述

2.创建一个自定义校验器,实现上面的校验器接口
在这里插入图片描述

implements ConstraintValidator<ListValue,Integer>//第一个字段写入自定义注解的名字,第二个我们校验的属性是Integer类型,所以填入Integer

3.ConstraintValidator的实现,有两个方法,一个是初始化,一个是校验

    private Set<Integer> set = new HashSet<>();
    //初始化方法
    @Override
    public void initialize(ListValue constraintAnnotation) {
        int[] vals = constraintAnnotation.vals();//包含咱们自定义注解中的vals的值[0,1]
        for (int val : vals) {
            set.add(val);
        }
    }

    //判断是否校验成功

    /**
     *
     * @param integer 需要判断的值,比如传入3,是否符合0,1状态
     * @param constraintValidatorContext
     * @return
     */
    @Override
    public boolean isValid(Integer integer, ConstraintValidatorContext constraintValidatorContext) {
        return set.contains(integer);
    }

三、关联自定义的校验器和自定义的校验注解

在自定义注解里面引入自定义注解的校验器

validatedBy = {ListValueConstraintValidator.class可以指定多个校验器,校验不同类型的值】}

总结

自定义校验的实现三个步骤

  •  1).编写一个自定义的校验注解
    
  •  2).编写一个自定义的校验器
    
  •  3).关联自定义的校验器和自定义的校验注解validatedBy = {ListValueConstraintValidator.class可以指定多个校验器,校验不同类型的值】}
    

原文地址:https://blog.csdn.net/xyhxuyonghao/article/details/134683175

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_13405.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注