Java springboot @Constraint自定义验证注解

基本验证注解:
@Null 被注释的元素必须为 null
@NotNull 被注释的元素必须不为 null
@AssertTrue 被注释的元素必须为 true
@AssertFalse 被注释的元素必须为 false
@Min(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
@Max(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
@DecimalMin(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
@DecimalMax(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
@Size(max, min) 被注释的元素的大小必须在指定的范围内
@Digits (integer, fraction) 被注释的元素必须是一个数字,其值必须在可接受的范围内
@Past 被注释的元素必须是一个过去的日期
@Future 被注释的元素必须是一个将来的日期
@Pattern(value) 被注释的元素必须符合指定的正则表达式

自定义验证注解实现
1.定义注解

@Target({ElementType.FIELD,ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
//注解的逻辑实现类Judgeimpl
@Constraint(validatedBy = {Judgeimpl.class})
public @interface judge {
    //函数自己设计
    String message() default "名字格式错误";

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

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

}

补充

java四种原注解 @Target 表示该注解用于什么地方,可能的值在枚举类 ElemenetType 中,包括:

 ElemenetType.CONSTRUCTOR-----------------------------构造器声明 
 ElemenetType.FIELD ----------------------------------域声明(包括 enum 实例) 
 ElemenetType.LOCAL_VARIABLE------------------------- 局部变量声明 
 ElemenetType.METHOD ---------------------------------方法声明 
 ElemenetType.PACKAGE --------------------------------包声明 
 ElemenetType.PARAMETER ------------------------------参数声明 
 ElemenetType.TYPE----------------------------------- 类,接口(包括注解类型)或enum声明 

@Retention 表示在什么级别保存该注解信息。可选的参数值在枚举类型 RetentionPolicy 中,包括:

 RetentionPolicy.SOURCE-------------注解将被编译器丢弃 
 RetentionPolicy.CLASS -------------注解在class文件中可用,但会被VM丢弃 
 RetentionPolicy.RUNTIME ---------VM将在运行期也保留注释,因此可以通过反射机制读取注解的信息。

@Documented 将此注解包含在 javadoc 中
,它代表着此注解会被javadoc工具提取成文档。在doc文档中的内容会因为此注解的信息内容不同而不同。相当与@see,@param 等。

@Inherited 允许子类继承父类中的注解。

Annotation的一般形式是 :

public @interface MyAnnotation {  
    String value() default "hahaha";  
} 
其实等同于

public class MyAnnotation extends java.lang.annotation.Annotation{   
     private String value = "hahaha";   
     public void setValue(String value){   
          this.value = value;   
     }   
     public String getValue(){   
          return value;   
      }   
} 

2.实现类完成

public class Judgeimpl implements ConstraintValidator<judge,Object> {


    @Override
    public void initialize(judge judge) {
    //初始化 可以此处初始化一些变量
        System.out.println("init");
        System.out.println(judge.message());
       
    }

    @Override
    public boolean isValid(Object o, ConstraintValidatorContext constraintValidatorContext) {
        if(o==null){
            return false;
            
        }else if(o.toString().trim().equals("XXXX")){//验证字符串格式            //返回true表示验证通过
            return true;
        }
    	//返回false表示验证不通过
        return false;
    }
}

3.在实体类使用注解

@Data
public class Teacher {
	//自定义验证注解使用
    @judge
    String name;

   @Past(message = "不能是未来时间")
    Date birthday;


}

4.最后在controller接受参数加上@valid测试一下即可

@GetMapping("/test")
    @ResponseBody
    public String testTea(@Valid @RequestBody Teacher teacher){
        return teacher.getName();
    }
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值