JSR是JAVA Specification Requests的缩写,意思是Java 规范提案。是指向JCP(Java Community Process)提出新增 一个标准化技术规范的正式请求。任何人都可以提交JSR,以向Java平台增添新的API和服务。JSR已成为Java 界定的一个重要标准。
提供的注解都在 import
javax.validation.constraints这个包下面的
注解 @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);
}
复制代码
@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 {};
}
复制代码
自定义校验器
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);
}
}
复制代码
在自定义的注解上面将我们自定义的校验器进行绑定
@Constraint(validatedBy = {DataCheckVaildator.class})
复制代码
@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;
}
复制代码
不在规定返回之内:
返回提示信息
在规定返回之内时:
正常返回数据