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
*/