博客
关于我
JSR303自定义校验注解
阅读量:317 次
发布时间:2019-03-04

本文共 1908 字,大约阅读时间需要 6 分钟。

文章目录

1:JSR303自定义校验注解

问题:如果我们校验如下的方式是可以用正则表达式,可是有时候我们的业务只有正则也完成不了,所以我们需要自定义校验注解

/**	 * 显示状态[0-不显示;1-显示]	 */	 	@ListValue(vals={   0,1})	private Integer showStatus;
@ListValue(vals={0,1})就是我们需要编写的自定义校验注解

编写自定义校验注解思路:

1)编写一个自定义的校验注解
2)编写一个自定义的校验器
3)关联自定义的校验器和自定义的校验注解

1.1 第一步:编写一个自定义的校验注解@ListValue(我们可以参考一些已经实现的注解如@interface NotNull)

@ListValue(vals={   0,1})	private Integer showStatus;
//原信息数据 //可以标注在那些位置@Target({   ElementType.METHOD, ElementType.FIELD, ElementType.ANNOTATION_TYPE, ElementType.CONSTRUCTOR, ElementType.PARAMETER})//运行时获取到@Retention(RetentionPolicy.RUNTIME)@Documented//使用哪个校验器进行校验@Constraint( validatedBy = {   ListValueConstraintValidator.class})public @interface ListValue {      //校验出错以后去哪取(ValidationMessages.properties)取到javax.validation.constraints.NotNull.message这一个数据 //根据上面的思路,我们就可以自己在resources中创建ValidationMessages.properties,配置如下的内容    String message() default "{com.atstudying.common.valid.ListValue.message}";    //可以实现分组校验    Class
[] groups() default { }; //自定义一些负载信息 Class
[] payload() default { }; int [] vals() default { };}

在这里插入图片描述

1.2 第二步:编写一个自定义的校验器

在这里插入图片描述

在这里插入图片描述
ListValueConstraintValidator .java

public class ListValueConstraintValidator implements ConstraintValidator
{ private Set
set=new HashSet<>(); //初始化方法 @Override public void initialize(ListValue constraintAnnotation) { //获取详细信息vals={0,1}0,1 int [] vals=constraintAnnotation.vals(); for (int val :vals){ set.add(val); } } //判断是否校验成功 @Override public boolean isValid(Integer value, ConstraintValidatorContext constraintValidatorContext) { //如果我们获取值为3=value,传进来判断不会等于0,1就是返回false return set.contains(value); }}

1.3 第三步:关联自定义的校验器和自定义的校验注解

ListValue

@Constraint(        // Class
>[] validatedBy(); //可以指定多个不同的校验器,适配不同类型的校验 validatedBy = { ListValueConstraintValidator.class})

转载地址:http://zzhq.baihongyu.com/

你可能感兴趣的文章
MySQL中B+Tree索引原理
查看>>
mysql中cast() 和convert()的用法讲解
查看>>
mysql中datetime与timestamp类型有什么区别
查看>>
MySQL中DQL语言的执行顺序
查看>>
mysql中floor函数的作用是什么?
查看>>
MySQL中group by 与 order by 一起使用排序问题
查看>>
mysql中having的用法
查看>>
MySQL中interactive_timeout和wait_timeout的区别
查看>>
mysql中int、bigint、smallint 和 tinyint的区别、char和varchar的区别详细介绍
查看>>
mysql中json_extract的使用方法
查看>>
mysql中json_extract的使用方法
查看>>
mysql中kill掉所有锁表的进程
查看>>
mysql中like % %模糊查询
查看>>
MySql中mvcc学习记录
查看>>
mysql中null和空字符串的区别与问题!
查看>>