spring boot-@Validated参数校验-自定义注解(不为空才进行正则校验)
通过自定义注解,满足不为空才进行正则校验的需求import javax.validation.Constraint;import javax.validation.ConstraintValidator;import javax.validation.ConstraintValidatorContext;import javax.validation.Payload;import java.lan
·
通过自定义注解,满足不为空才进行正则校验的需求
/**
* @author LGQ
* @Title: 自定义注解整合jsr
* @Description: 不为空进行规则校验
* @date 2021/9/30 10:32
*/
@Target({METHOD, FIELD, ANNOTATION_TYPE, CONSTRUCTOR, PARAMETER, TYPE_USE})
@Retention(RetentionPolicy.RUNTIME)
@Constraint(validatedBy = NotBlankThenPattern.NotBlankThenPatternValidation.class)
@Documented
public @interface NotBlankThenPattern {
String regexp() default "";
String message() default "格式错误";
/**
* @return the groups the constraint belongs to
*/
Class<?>[] groups() default {};
/**
* @return the payload associated to the constraint
*/
Class<? extends Payload>[] payload() default {};
class NotBlankThenPatternValidation implements ConstraintValidator<NotBlankThenPattern, String> {
private Pattern pattern;
@Override
public void initialize(NotBlankThenPattern constraintAnnotation) {
this.pattern = Pattern.compile(constraintAnnotation.regexp());
}
@Override
public boolean isValid(String value, ConstraintValidatorContext context) {
if (StringUtil.isBlank(value)) {
return true;
}
return pattern.matcher(value).matches();
}
}
}
@RestControllerAdvice
@Slf4j
public class CommonExceptionHandler {
@ExceptionHandler({MethodArgumentNotValidException.class})
public Result handleMethodArgumentNotValidException(MethodArgumentNotValidException ex) {
BindingResult bindingResult = ex.getBindingResult();
StringBuilder sb = new StringBuilder("");
if (null != bindingResult.getFieldErrors()) {
for (FieldError fieldError : bindingResult.getFieldErrors()) {
sb.append(fieldError.getDefaultMessage() + "\n");
}
return Result.ofFail(-1, sb.toString());
}
return Result.ofSuccessMsg(null);
}
}
更多推荐
已为社区贡献1条内容
所有评论(0)