Bean Validation 规范提供了一种强大的机制,用于验证 Java Bean 的属性。当需要验证集合(例如 List)中的元素时,可以使用容器元素约束。本文将详细介绍如何使用 @Pattern 注解结合容器元素约束,对字符串列表中的邮箱地址进行校验,确保它们都以 @gmail.com 结尾。
容器元素约束允许您对集合中的每个元素应用约束。这对于验证集合中的数据非常有用,例如验证邮箱地址列表、电话号码列表等。在 Bean Validation 2.0 及更高版本中,可以通过在泛型类型参数前添加约束注解来实现容器元素约束。
假设我们有一个 List
import javax.validation.constraints.Pattern;
import java.util.List;
public class EmailList {
private List<@Pattern(regexp = "^(.+)@(gmail\\.com)$") String> emails;
public List getEmails() {
return emails;
}
public void setEmails(List emails) {
this.emails = emails;
}
} 代码解释:
import javax.validation.Validation;
import javax.validation.Validator;
import javax.validation.ValidatorFactory;
import java.util.Arrays;
import java.util.List;
import java.util.Set;
import javax.validation.ConstraintViolation;
public class Main {
public static void main(String[] args) {
ValidatorFactory factory = Validation.buildDefaultValidatorFactory();
Validator validator = factory.getValidator();
EmailList emailList = new EmailList();
List emails = Arrays.asList("valid.email@gmail.com", "invalid.email@example.com");
emailList.setEmails(emails);
Set> violations = validator.validate(emailList);
if (!violations.isEmpty()) {
for (ConstraintViolation violation : violations) {
System.err.println(violation.getPropertyPath() + " : " + violation.getMessage());
}
} else {
System.out.println("Validation successful!");
}
}
} 运行结果:
emails[1] : must match "^(.+)@(gmail\.com)$"
代码解释:
org.hibernate.validator hibernate-validator6.2.0.Final org.glassfish jakarta.el4.0.2
通过结合 @Pattern 注解和容器元素约束,可以方便地对集合中的元素进行模式验证,从而确保数据的有效性和一致性。 本文提供了一个验证邮箱域名列表的示例,您可以根据实际需求修改正则表达式,以适应不同的验证场景。 掌握容器元素约束的使用,可以提高数据校验的灵活性和可维护性。