javax.validation使用@Pattern空字段校验跳过

在 Java Bean Validation 中使用 @Pattern 注解时,默认会校验空字符串("")。若需要跳过空字符串的校验,可通过以下方法实现:

解决方案:自定义校验器

创建一个跳过空字符串的校验注解 @EmptyPattern

import javax.validation.Constraint;
import javax.validation.Payload;
import java.lang.annotation.*;

/**
 * 空的字符传不进行正则表达式校验
 */
@Documented
@Constraint(validatedBy = EmptyPatternValidator.class)
@Target({ElementType.FIELD, ElementType.PARAMETER})
@Retention(RetentionPolicy.RUNTIME)
public @interface EmptyPattern {
    String message() default "";
    Class<?>[] groups() default {};
    Class<? extends Payload>[] payload() default {};
    String regexp();
}
import javax.validation.ConstraintValidator;
import javax.validation.ConstraintValidatorContext;
import java.util.regex.Pattern;

public class EmptyPatternValidator implements ConstraintValidator<EmptyPattern, String> {
    private java.util.regex.Pattern pattern;

    @Override
    public void initialize(EmptyPattern constraintAnnotation) {
        this.pattern = Pattern.compile(constraintAnnotation.regexp());
    }

    @Override
    public boolean isValid(String value, ConstraintValidatorContext context) {
        // 空字符串直接通过校验
        if (value == null || value.isEmpty()) {
            return true;
        }
        return pattern.matcher(value).matches();
    }
}

使用示例

在实体类中替换 @Pattern 为自定义注解:

public class User {
    @EmptyPattern(regexp = "^[a-zA-Z0-9]{5,10}$") // 允许空字符串
    private String username;
}

效果说明

  1. 空字符串 "":直接通过校验(返回 true
  2. 非空字符串:执行正则匹配(如 "abc123" 需符合 ^[a-zA-Z0-9]{5,10}$
  3. null:默认通过(需配合 @NotNull 单独控制)

组合校验建议

若需区分空字符串和 null

  • 允许空字符串但禁止 null:添加 @NotNull
  • @NotNull
    @EmptyPattern(regexp = "...")
    private String field;
  • 完全跳过空值:使用原生 @Pattern + @NotBlank 组合

注意:此方案基于 Hibernate Validator 实现,需确保依赖正确配置(如 spring-boot-starter-validation)。正则表达式语法遵循 Java 标准库规范。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值