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 标准库规范。

`javax.validation`是Java EE规范中的一部分,主要提供了数据校验的功能。通过使用注解的方式,开发者可以在实体类中直接定义校验规则,从而在数据持久化到数据库之前对其进行校验。`@Pattern(regexp='正则表达式')`是该规范提供的校验注解之一,用于校验字符串字段是否符合指定的正则表达式。 例如,如果有一个字段需要校验为电子邮件格式,可以使用`@Pattern`注解配合相应的正则表达式来实现: ```java import javax.validation.constraints.Pattern; public class User { @Pattern(regexp="^[\\w-\\.]+@([\\w-]+\\.)+[\\w-]{2,4}$") private String email; // 其他字段和方法... } ``` 在实际应用中,如果校验失败,`javax.validation`会抛出`ConstraintViolationException`异常。为了处理这个异常,开发者通常需要在业务逻辑层面上捕获它,并根据异常内容给出相应的处理。 异常处理通常涉及到以下几个步骤: 1. 捕获异常:使用try-catch块来捕获`ConstraintViolationException`。 2. 获取错误信息:从异常中提取出所有的校验错误信息。 3. 反馈给用户:将错误信息整理后反馈给用户,提示其输入正确的数据。 异常处理示例代码如下: ```java try { // 这里是业务逻辑,调用了需要校验的方法 } catch (ConstraintViolationException e) { Set<ConstraintViolation<?>> violations = e.getConstraintViolations(); for (ConstraintViolation<?> violation : violations) { // 这里可以获取具体的校验错误信息,并进行处理 } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值