博客
关于我
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-Explain的详解
查看>>
mysql-group_concat
查看>>
MySQL-redo日志
查看>>
MySQL-【1】配置
查看>>
MySQL-【4】基本操作
查看>>
Mysql-丢失更新
查看>>
Mysql-事务阻塞
查看>>
Mysql-存储引擎
查看>>
mysql-开启慢查询&所有操作记录日志
查看>>
MySQL-数据目录
查看>>
MySQL-数据页的结构
查看>>
MySQL-架构篇
查看>>
MySQL-索引的分类(聚簇索引、二级索引、联合索引)
查看>>
Mysql-触发器及创建触发器失败原因
查看>>
MySQL-连接
查看>>
mysql-递归查询(二)
查看>>
MySQL5.1安装
查看>>
mysql5.5和5.6版本间的坑
查看>>
mysql5.5最简安装教程
查看>>
mysql5.6 TIME,DATETIME,TIMESTAMP
查看>>