博客
关于我
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中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
查看>>
mysql中实现rownum,对结果进行排序
查看>>
mysql中对于数据库的基本操作
查看>>
Mysql中常用函数的使用示例
查看>>
MySql中怎样使用case-when实现判断查询结果返回
查看>>
Mysql中怎样使用update更新某列的数据减去指定值
查看>>
Mysql中怎样设置指定ip远程访问连接
查看>>
mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
查看>>
Mysql中文乱码问题完美解决方案
查看>>
mysql中的 +号 和 CONCAT(str1,str2,...)
查看>>
Mysql中的 IFNULL 函数的详解
查看>>
mysql中的collate关键字是什么意思?
查看>>
MySql中的concat()相关函数
查看>>
mysql中的concat函数,concat_ws函数,concat_group函数之间的区别
查看>>
MySQL中的count函数
查看>>
MySQL中的DB、DBMS、SQL
查看>>
MySQL中的DECIMAL类型:MYSQL_TYPE_DECIMAL与MYSQL_TYPE_NEWDECIMAL详解
查看>>
MySQL中的GROUP_CONCAT()函数详解与实战应用
查看>>
MySQL中的IO问题分析与优化
查看>>
MySQL中的ON DUPLICATE KEY UPDATE详解与应用
查看>>