java& JSR303之自定义校验注解
什么是JSR303
JSR是Java Specification Requests的缩写,意思是Java 规范提案。是指向JCP(Java Community Process)提出新增 一个标准化技术规范的正式请求。任何人都可以提交JSR,以向Java平台增添新的API和服务。JSR已成为Java 界的一个重要标准。
自带的校验注解都有哪些?
提供的注解都在 import javax.validation.constraints这个包下面的
下面我们先简单的使用下基本注解校验
首先我们先准备一个VO
注解 @NotNull 校验 page 和 limit 属性 这里手动制定了message 如果不手动指定的话会去加载默认的message ValidationMessages.properties文件中
@Data
@ApiModel(description= "ListVO")
public class ListVo {
@NotNull(message = "页码不能为空")
@ApiModelProperty(value = "页码")
private Integer page;
@NotNull(message = "分页大小不能为空")
@ApiModelProperty(value = "分页大小")
private Integer limit;
@ApiModelProperty(value = "搜索条件")
private Object searchObj;
}
开启注解校验
@Valid 开启校验,BindingResult 紧跟着注解校验对象后面可以获取到校验结果
@PostMapping("/getlist")
@SysOperaLog("获取日志列表")
public R getlist(@Valid @RequestBody ListVo parm, BindingResult bindingResult){
if(bindingResult.hasErrors()){
Map<String,Object> map = new HashMap<>();
bindingResult.getFieldErrors().forEach((e)->{
//错误提示信息
String defaultMessage = e.getDefaultMessage();
//出问题的属性
String field = e.getField();
map.put("message",defaultMessage);
map.put("field",field);
});
return R.error().data(map);
}
return iLogService.getList(parm);
}
下面我们使用 postman 测试一下
下面我们使用以下 如何使用 自定义校验
1. 编写一个自定义的校验注解
@DataCheck 注解
//可以被标注到那个地方
@Target({ElementType.METHOD, ElementType.FIELD, ElementType.ANNOTATION_TYPE, ElementType.CONSTRUCTOR, ElementType.PARAMETER, ElementType.TYPE_USE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
//这里指向的是我们自定义的校验规则,可以治党多个不同校验器,适配不同的情况
@Constraint(validatedBy = {DataCheckVaildator.class})
public @interface DataCheck {
//当然这里的message也可以去属性文件中指定
String message() default "请提交规范数据";
Class<?>[] groups() default {};
Class<? extends Payload>[] payload() default {};
//用来获取注解属性值
int[] vals() default {};
}
2. 编写一个自定义的校验器
自定义校验器
public class DataCheckVaildator implements ConstraintValidator<DataCheck,Integer> {
private Set<Integer> setNum = new HashSet<>();
//初始化方法
@Override
public void initialize(DataCheck constraintAnnotation) {
int[] vals = constraintAnnotation.vals();
for (int val : vals) {
setNum.add(val);
}
}
@Override
public boolean isValid(Integer integer, ConstraintValidatorContext constraintValidatorContext) {
//如果包含我们规定的 数据就会返回true 不包含就会返回false
return setNum.contains(integer);
}
}
3. 关联自定义的校验注解和自定义的校验器
在自定义的注解上面讲我们自定义的校验器进行绑定
@Constraint(validatedBy = {DataCheckVaildator.class})
使用@DataCheck 进行分页大小的校验 只能传递 10,20,30,40,50
@Data
@ApiModel(description= "ListVO")
public class ListVo {
@NotNull(message = "页码不能为空")
@ApiModelProperty(value = "页码")
private Integer page;
@NotNull(message = "分页大小不能为空")
@DataCheck(vals={10,20,30,40,50})
@ApiModelProperty(value = "分页大小")
private Integer limit;
@ApiModelProperty(value = "搜索条件")
private Object searchObj;
}
使用Postman调用 可以看到 limit 传递的值不在 规定返回之内时完成校验
不在规定返回之内:
返回提示信息
在规定返回之内时:
正常返回数据
实践是检验真理的唯一方法! 明天见🥰🥰🥰
转载自:https://juejin.cn/post/7108183558095077407