博客
关于我
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自增id超大问题查询
查看>>
MySQL视图
查看>>
MySQL设置远程连接
查看>>
MySQL迁移到达梦:如何轻松、高质量完成迁移任务
查看>>
mysql还有哪些自带的函数呢?别到处找了,看这个就够了。
查看>>
mysql进阶 with-as 性能调优
查看>>
Mysql连接时报时区错误
查看>>
MYSQL遇到Deadlock found when trying to get lock,解决方案
查看>>
mysql部署错误
查看>>
MySQL锁与脏读、不可重复读、幻读详解
查看>>
mysql锁机制,主从复制
查看>>
Mysql锁机制,行锁表锁
查看>>
MySQL集群解决方案(4):负载均衡
查看>>
mysql面试题学校三表查询_mysql三表查询分组后取每组最大值,mysql面试题。
查看>>
Mysql面试题精选
查看>>
MySQL面试题集锦
查看>>
mysql颠覆实战笔记(八)--mysql的自定义异常处理怎么破
查看>>
mysql驱动、durid、mybatis之间的关系
查看>>
mysql驱动支持中文_mysql 驱动包-Go语言中文社区
查看>>
MySQL高可用切换_(5.9)mysql高可用系列——正常主从切换测试
查看>>