import static java.lang.annotation.RetentionPolicy.RUNTIME;
/**
* 自定义校验注解
*/
@Documented
// 这里需要自定义校验器ListValueConstraintValidator,可以指定多个不同的校验器,适配不同类型的校验
@Constraint(validatedBy = {ListValueConstraintValidator.class})
@Target({ METHOD, FIELD, ANNOTATION_TYPE, CONSTRUCTOR, PARAMETER, TYPE_USE })
@Retention(RUNTIME)
public @interface ListValue {
// 这里的默认值需要和resources中的配置文件的值相同
String message() default “{com.pumpkin.common.valid.ListValue.message}”;
Class<?>[] groups() default { };
Class<? extends Payload>[] payload() default { };
int[] values() default { };
}
注:该类除了`values数组`,其他属性和注解都是遵循`JSR303规范`来实现的,也就是直接复制过来即可
##### 3、 在resources目录中添加配置文件
**首先添加依赖:**
<dependency>
<groupId>javax.validation</groupId>
<artifactId>validation-api</artifactId>
<version>2.0.1.Final</version>
</dependency>
**文件名:** ValidationMessages.properties ,这个名字依据org\hibernate\validator\ValidationMessages.properties这个包下的来写,不能更改,否则注解下面配置文件不生效
com.pumpkin.common.valid.ListValue.message=必须提交指定的值
###### 4、 创建ListValueConstraintValidator来自定义校验器
package com.pumpkin.common.valid;
import javax.validation.ConstraintValidator;
import javax.validation.ConstraintValidatorContext;
import java.util.HashSet;
import java.util.Set;public class ListValueConstraintValidator implements ConstraintValidator<ListValue, Integer> {
// 定义set属性来保存values数组的值,set可以避免重复值
private Set set = new HashSet<>();
/\*\*
* 初始化方法
* @param constraintAnnotation
*/
@Override
public void initialize(ListValue constraintAnnotation) {
// 1.得到所有的值
int[] values = constraintAnnotation.values();
// 2.遍历数组并添加到set集合中
for (int value : values) {
set.add(value);
}
}
/\*\*
* 判断校验是否成功
* @param value 需要校验的值: 前端提交过来的值
* @param context
* @return
*/