首页 > Java > java教程 > 正文

使用 Bean Validation 约束列表中的字符串:限定邮箱域名

心靈之曲
发布: 2025-10-07 12:11:01
原创
487人浏览过

使用 bean validation 约束列表中的字符串:限定邮箱域名

Bean Validation 规范提供了一种强大的机制,用于验证 Java Bean 的属性。当需要验证集合(例如 List)中的元素时,可以使用容器元素约束。本文将详细介绍如何使用 @Pattern 注解结合容器元素约束,对字符串列表中的邮箱地址进行校验,确保它们都以 @gmail.com 结尾。

容器元素约束简介

容器元素约束允许您对集合中的每个元素应用约束。这对于验证集合中的数据非常有用,例如验证邮箱地址列表、电话号码列表等。在 Bean Validation 2.0 及更高版本中,可以通过在泛型类型参数前添加约束注解来实现容器元素约束。

使用 @Pattern 验证邮箱域名

假设我们有一个 List<String>,其中包含邮箱地址,我们希望确保所有邮箱地址都以 @gmail.com 结尾。可以使用以下代码实现:

import javax.validation.constraints.Pattern;
import java.util.List;

public class EmailList {

    private List<@Pattern(regexp = "^(.+)@(gmail\.com)$") String> emails;

    public List<String> getEmails() {
        return emails;
    }

    public void setEmails(List<String> emails) {
        this.emails = emails;
    }
}
登录后复制

代码解释:

奇域
奇域

奇域是一个专注于中式美学的国风AI绘画创作平台

奇域 30
查看详情 奇域
  • @Pattern(regexp = "^(.+)@(gmail\.com)$"): 这个注解应用于 List<String> 的泛型类型参数 String 之前,表示对列表中的每个字符串元素应用正则表达式约束。
    • regexp = "^(.+)@(gmail\.com)$": 这是一个正则表达式,用于匹配以 @gmail.com 结尾的邮箱地址。
      • ^: 匹配字符串的开头。
      • (.+): 匹配一个或多个任意字符(除了换行符)。
      • @: 匹配 @ 字符。
      • gmail\.com: 匹配 gmail.com 字符串,注意 . 需要转义。
      • $: 匹配字符串的结尾。

示例代码

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<String> emails = Arrays.asList("valid.email@gmail.com", "invalid.email@example.com");
        emailList.setEmails(emails);

        Set<ConstraintViolation<EmailList>> violations = validator.validate(emailList);

        if (!violations.isEmpty()) {
            for (ConstraintViolation<EmailList> violation : violations) {
                System.err.println(violation.getPropertyPath() + " : " + violation.getMessage());
            }
        } else {
            System.out.println("Validation successful!");
        }
    }
}
登录后复制

运行结果:

emails[1] : must match "^(.+)@(gmail.com)$"
登录后复制

代码解释:

  1. 创建 ValidatorFactory 和 Validator: 使用 Validation.buildDefaultValidatorFactory() 创建一个 ValidatorFactory,然后使用 factory.getValidator() 获取一个 Validator 实例。
  2. 创建 EmailList 对象: 创建一个 EmailList 对象,并设置包含有效和无效邮箱地址的列表。
  3. 验证对象: 使用 validator.validate(emailList) 验证 EmailList 对象。 validate() 方法返回一个 Set<ConstraintViolation<EmailList>>,其中包含所有验证失败的约束。
  4. 处理验证结果: 如果 violations 集合不为空,则遍历集合并打印每个验证失败的约束信息。 否则,打印 "Validation successful!"。

注意事项

  • 确保你的项目中包含 Bean Validation 的依赖。可以使用 Maven 或 Gradle 等构建工具添加依赖。例如,在 Maven 中,可以添加以下依赖:
<dependency>
    <groupId>org.hibernate.validator</groupId>
    <artifactId>hibernate-validator</artifactId>
    <version>6.2.0.Final</version> <!-- 请使用最新版本 -->
</dependency>
<dependency>
    <groupId>org.glassfish</groupId>
    <artifactId>jakarta.el</artifactId>
    <version>4.0.2</version> <!-- 请使用最新版本 -->
</dependency>
登录后复制
  • 正则表达式需要进行转义,例如 . 需要转义为 \., 本身也需要转义为 \\。
  • 如果需要支持不同的邮箱域名,可以将正则表达式配置为可配置的属性。

总结

通过结合 @Pattern 注解和容器元素约束,可以方便地对集合中的元素进行模式验证,从而确保数据的有效性和一致性。 本文提供了一个验证邮箱域名列表的示例,您可以根据实际需求修改正则表达式,以适应不同的验证场景。 掌握容器元素约束的使用,可以提高数据校验的灵活性和可维护性。

以上就是使用 Bean Validation 约束列表中的字符串:限定邮箱域名的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号