【Springboot之参数校验2】自定义注解实现入参指定枚举值
2018-12-20 本文已影响11人
zetting
通过自定义枚举注解
@EnumValidator(value = SexEnums.class),
private Integer sex;
就可以校验入参值必须在指定枚举类中
原创:https://www.jianshu.com/p/32f0d6e3afbb
目录
- 自定义枚举校验注解
- 使用枚举校验注解
- 演示
- 附
自定义枚举校验注解
1.定义自定义枚举@EnumValidator
package com.code2.base;
import javax.validation.Constraint;
import javax.validation.Payload;
import java.lang.annotation.*;
/**
* 枚举值校验注解
*
* @author: zet
* @date:2018/12/18
*/
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.FIELD, ElementType.METHOD})
@Constraint(validatedBy = EnumValidatorClass.class)
public @interface EnumValidator {
Class<?> value();
String message() default "入参值不在正确枚举中";
Class<?>[] groups() default {};
Class<? extends Payload>[] payload() default {};
}
2.定义实现枚举值校验处理类EnumValidatorClass
package com.code2.base;
import lombok.extern.slf4j.Slf4j;
import javax.validation.ConstraintValidator;
import javax.validation.ConstraintValidatorContext;
import java.lang.annotation.Annotation;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.List;
import java.util.Objects;
/**
* 枚举值校验注解实现
*
* @author: zet
* @date:2018/12/18
*/
@Slf4j
public class EnumValidatorClass implements ConstraintValidator<EnumValidator, Object>, Annotation {
private List<Object> values = new ArrayList<>();
@Override
public void initialize(EnumValidator enumValidator) {
Class<?> clz = enumValidator.value();
Object[] ojects = clz.getEnumConstants();
try {
Method method = clz.getMethod("getValue");
if (Objects.isNull(method)) {
throw new Exception(String.format("枚举对象{}缺少字段名为value的字段",
clz.getName()));
}
Object value = null;
for (Object obj : ojects) {
value = method.invoke(obj);
values.add(value);
}
} catch (Exception e) {
log.error("[处理枚举校验异常]", e);
}
}
@Override
public Class<? extends Annotation> annotationType() {
return null;
}
@Override
public boolean isValid(Object value, ConstraintValidatorContext constraintValidatorContext) {
return Objects.isNull(value) || values.contains(value) ? true : false;
}
}
使用枚举校验注解
1.定义要校验的枚举值
package com.code2.modules.enums;
import lombok.Getter;
/**
* 性别枚举
*
* @author: zet
* @date: 2018/12/20 22:41
*/
public enum SexEnums {
/**
* 未知
*/
UNKNOWN(0),
/**
* 男
*/
MALE(1),
/**
* 女
*/
FEMALE(2);
@Getter
private int value;
SexEnums(int value) {
this.value = value;
}
}
2.在相应要检验的字段加上@EnumValidator注解
package com.code2.modules.dto;
import com.code2.aop.Request;
import com.code2.base.EnumValidator;
import com.code2.modules.enums.SexEnums;
import lombok.Data;
import org.hibernate.validator.constraints.NotBlank;
import javax.validation.constraints.NotNull;
/**
* 入参校验请求
*
* @author: zet
* @date: 2018/12/19 22:16
*/
@Data
public class ValidateRequest extends Request {
/**
* 用户名
*/
@NotBlank
private String userName;
/**
* 性别
*/
@EnumValidator(value = SexEnums.class)
private Integer sex;
/**
* 地址
*/
private String address;
}
2.controller层正常使用、无需添加任何东西
package com.code1.modules.controller;
import com.code1.modules.dto.ValidateRequest;
import com.code1.base.Response;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
/**
* 第一个springboot应用
*
* @author oKong
*/
@RestController
@RequestMapping("/param/")
public class MyController {
@GetMapping(value = "/validate")
public Response validate(ValidateRequest request) {
return Response.success();
}
}
演示
1.入参不再枚举值中
入参不再指定的枚举中.jpg
2.入参在枚举值中
入参在指定的枚举中.jpg
附
gitee源码:
https://gitee.com/Zetting/my-gather/tree/master/code2-enum-validate