参数校验
1. @Validated
它的实现相当于是一个AOP,所以当使用private的时候无法找到对应的接口;而springMCV是通过反射的方式拿到的接口所以不会报错,实现类
org.springframework.boot.autoconfigure.validation.ValidationAutoConfiguration
所以它就可以标注在类上,那么就会有代理这个类,会解析到当前方法的参数并进行校验
- org.springframework.boot.autoconfigure.validation.ValidationAutoConfiguration#methodValidationPostProcessor
- org.springframework.validation.beanvalidation.MethodValidationPostProcessor#afterPropertiesSet
- org.springframework.validation.beanvalidation.MethodValidationPostProcessor#createMethodValidationAdvice
- org.springframework.validation.beanvalidation.MethodValidationInterceptor#invoke
2. @Valid
它的实现是通过springMVC的参数解析器实现的,在方法执行之前,判断是否有@Valid注解,然后调用其中的参数解析器进行参数的校验
3. 自定义参数解析
package com.stringboot.util;
import org.springframework.context.support.DefaultMessageSourceResolvable;
import javax.validation.ConstraintViolation;
import javax.validation.Validation;
import javax.validation.Validator;
import javax.validation.ValidatorFactory;
import java.util.Set;
import java.util.stream.Collectors;
/**
* @Description 实体属性格式验证
* @Param
* @return
**/
public class ValidatorUtil {
private static ValidatorFactory factory = Validation.buildDefaultValidatorFactory();
/**
* 实体属性格式验证(一次性返回所有验证结果)
*
* @param t 实体集
* @param <T> 实体
* @return 返回结果
*/
public static <T> String validates(T t, Class<?>... groups) {
Validator validator = factory.getValidator();
Set<ConstraintViolation<T>> constraintViolations = validator.validate(t,groups);
String error = null;
// 判断是否有验证的错误
if (null != constraintViolations && constraintViolations.size() > 0){
error = constraintViolations.stream().map(ConstraintViolation::getMessage).collect(Collectors.joining(";"));
}
return error;
}
}