参考资料:
https://blog.csdn.net/weixin_37199234/article/details/107253433
https://www.csdn.net/tags/NtTaUg0sMTA0NjMtYmxvZwO0O0OO0O0O.html
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-validation</artifactId>
</dependency>
@NotBlank(message = "品牌名必须提交")
private String name;
// BindingResult中封装了校验结果,必须紧跟@Valid
@RequestMapping("/save")
public R save(@Valid @RequestBody BrandEntity brand) {
brandService.save(brand);
return R.ok();
}
/**
* 集中处理所有异常
*/
@Slf4j
@RestControllerAdvice(basePackages = "com.liu.gulimall.product.controller")
public class ProductControllerAdvice {
@ExceptionHandler(value = MethodArgumentNotValidException.class)
public R handleValidException(MethodArgumentNotValidException e) {
log.error("提交数据校验异常{}", e.getMessage());
BindingResult result = e.getBindingResult();
Map<String, String> errorMap = new HashMap<>();
result.getFieldErrors().forEach((item) -> {
String message = item.getDefaultMessage();
String field = item.getField();
errorMap.put(field, message);
});
return R.error(BizCodeEnume.VAILD_EXCEPTION.getCode(), BizCodeEnume.VAILD_EXCEPTION.getMsg()).put("data", errorMap);
}
@ExceptionHandler(value = Throwable.class)
public R handleValidException(Throwable throwable) {
return R.error(BizCodeEnume.UNKNOW_EXCEPTION.getCode(), BizCodeEnume.UNKNOW_EXCEPTION.getMsg());
}
}
可以针对不同操作url传来的行为进行分组,比如update传来的需要进行非空校验,save传来的可以不进行非空校验
public interface AddGroup {
}
public interface UpdateGroup {
}
@NotBlank(message = "品牌名不能为空", groups = {AddGroup.class, UpdateGroup.class})
private String name;
@RequestMapping("/save")
public R save(@Validated({AddGroup.class}) @RequestBody BrandEntity brand)
@Documented
@Constraint(validatedBy = { })
@Target({METHOD, FIELD, ANNOTATION_TYPE, CONSTRUCTOR, PARAMETER, TYPE_USE})
@Retention(RUNTIME)
public @interface ListValue {
// 必备
String message() default "{com.liu.common.valid.ListValue.message}";
// 必备
Class<?>[] groups() default {};
// 必备
Class<? extends Payload>[] payload() default {};
// 写明白传入什么值
int[] vals() default {};
}
com.liu.common.valid.ListValue.message = 必须提交指定值
/**
* 自定义校验器
*/
// 实现ConstraintValidator接口,第一个泛型为注释类,第二个泛型为注释标注在什么类型上面
public class ListValueConstraintValidator implements ConstraintValidator<ListValue, Integer> {
private Set<Integer> set = new HashSet<>();
/**
* 初始化方法
* @param constraintAnnotation 注解
*/
@Override
public void initialize(ListValue constraintAnnotation) {
// ConstraintValidator.super.initialize(constraintAnnotation);
int[] vals = constraintAnnotation.vals();
for (int val : vals) {
set.add(val);
}
}
/**
* 判断是否校验成功
* @param value 需要校验的值
* @param context
* @return
*/
@Override
public boolean isValid(Integer value, ConstraintValidatorContext context) {
return set.contains(value);
}
}
@Documented
@Constraint(validatedBy = {ListValueConstraintValidator.class})
@Target({METHOD, FIELD, ANNOTATION_TYPE, CONSTRUCTOR, PARAMETER, TYPE_USE})
@Retention(RUNTIME)
public @interface ListValue {
// BindingResult中封装了校验结果,必须紧跟@Valid
@RequestMapping("/save")
public R save(@Valid @RequestBody BrandEntity brand, BindingResult result) {
brandService.save(brand);
return R.ok();
}
/**
* 集中处理所有异常
*/
@Slf4j
@RestControllerAdvice(basePackages = "com.liu.gulimall.product.controller")
public class ProductControllerAdvice {
@ExceptionHandler(value = MethodArgumentNotValidException.class)
public R handleValidException(MethodArgumentNotValidException e) {
log.error("提交数据校验异常{}", e.getMessage());
BindingResult result = e.getBindingResult();
Map<String, String> errorMap = new HashMap<>();
result.getFieldErrors().forEach((item) -> {
String message = item.getDefaultMessage();
String field = item.getField();
errorMap.put(field, message);
});
return R.error(BizCodeEnume.VAILD_EXCEPTION.getCode(), BizCodeEnume.VAILD_EXCEPTION.getMsg()).put("data", errorMap);
}
@ExceptionHandler(value = Throwable.class)
public R handleValidException(Throwable throwable) {
log.error("错误内容", throwable);
return R.error(BizCodeEnume.UNKNOW_EXCEPTION.getCode(), BizCodeEnume.UNKNOW_EXCEPTION.getMsg());
}
}
// entity属性
@NotNull(message = "修改必须指定品牌id", groups = {UpdateGroup.class})
@Null(message = "新增不能指定id", groups = {AddGroup.class})
@TableId
private Long brandId;
@NotNull(message = "显示状态不能为空")
private Integer showStatus;
// controller方法只会检验brandId,不会检验showStatus
@RequestMapping("/save")
@Validated({AddGroup.class})
public R save( @RequestBody BrandEntity brand)
注解 | 描述 |
---|---|
@Valid | 对po实体进行校验 |
@AssertFalse | 所注解的元素必须是Boolean类型,且值为false |
@AssertTrue | 所注解的元素必须是Boolean类型,且值为true |
@DecimalMax | 所注解的元素必须是数字,且值小于等于给定的值 |
@DecimalMin | 所注解的元素必须是数字,且值大于等于给定的值 |
@Digits | 所注解的元素必须是数字,且值必须是指定的位数 |
@Future | 所注解的元素必须是将来某个日期 |
@Max | 所注解的元素必须是数字,且值小于等于给定的值 |
@Min | 所注解的元素必须是数字,且值大于等于给定的值 |
@Range | 所注解的元素需在指定范围区间内 |
@NotEmpty | 集合不能为空,用在集合类上面 |
@NotNull | 所注解的元素值不能为null,用在基本类型上 |
@NotBlank | 所注解的元素值有内容,用在String上面 |
@Null | 所注解的元素值为null |
@Past | 所注解的元素必须是某个过去的日期 |
@PastOrPresent | 所注解的元素必须是过去某个或现在日期 |
@Pattern | 所注解的元素必须满足给定的正则表达式 |
@Size | 所注解的元素必须是String、集合或数组,且长度大小需保证在给定范围之内 |
所注解的元素需满足Email格式 |