基本验证注解:
@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();
}