0

0

如何在枚举驱动的 DTO 中实现基于类型的数据格式校验

心靈之曲

心靈之曲

发布时间:2026-01-10 15:47:36

|

381人浏览过

|

来源于php中文网

原创

如何在枚举驱动的 DTO 中实现基于类型的数据格式校验

本文介绍如何根据 `contacttype` 枚举值(如 `email` 或 `phonenumber`)对 `contactvalue` 字段执行差异化校验:手机号仅允许数字,邮箱则需支持更复杂的字符组合,并提供可扩展的正则驱动校验方案。

在构建领域模型(如 ContactDTO)时,常需根据业务类型动态约束字段格式。例如,当 contacttype 为 PHONENUMBER 时,contactvalue 必须纯数字;而为 EMAIL 时,则需兼容 @、.、下划线、连字符等合法邮箱字符——此时简单的 isAlphanumeric() 校验会误判(如 "user.name@domain.co.uk" 含点号和 @,非纯字母数字)。

✅ 推荐方案:枚举内聚校验逻辑(高可维护性)

将校验规则封装进 ContactType 枚举中,既保证类型安全,又便于后续新增类型(如 WECHAT_ID、QQ_NUMBER):

import java.util.regex.Pattern;

public enum ContactType {
    PHONENUMBER("^\\d+$"),           // 纯数字,至少一位
    EMAIL("^[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\\.[A-Za-z]{2,}$"); // RFC 5322 简化版

    private final Pattern pattern;

    ContactType(String regex) {
        this.pattern = Pattern.compile(regex);
    }

    public void validate(String input) {
        if (input == null || input.trim().isEmpty()) {
            throw new IllegalArgumentException(name() + " value cannot be null or empty");
        }
        if (!pattern.matcher(input.trim()).matches()) {
            throw new IllegalArgumentException(
                String.format("%s value '%s' does not match required format", name(), input)
            );
        }
    }
}

对应 DTO 中的设置方法简洁清晰:

神卷标书
神卷标书

神卷标书,专注于AI智能标书制作、管理与咨询服务,提供高效、专业的招投标解决方案。支持一站式标书生成、模板下载,助力企业轻松投标,提升中标率。

下载
public class ContactDTO {
    private ContactType contactType;
    private String contactValue;
    private Long studentId;

    public void setContact(ContactType type, String value) {
        type.validate(value); // ✅ 统一入口,自动路由到对应规则
        this.contactType = type;
        this.contactValue = value.trim();
    }

    // getter/setter 省略...
}

⚠️ 注意事项与最佳实践

  • 邮箱校验勿过度简化:避免使用 StringUtils.isAlphanumeric(),它会拒绝所有合法邮箱中的 @、.、+、-、_ 等字符;
  • 空值与空白处理:validate() 方法应主动检查 null 和空白字符串,防止后续 NPE 或脏数据;
  • 正则性能足够:单次匹配开销极小,且 Pattern 在枚举构造时已编译复用,无需担心性能损耗;
  • 测试覆盖建议:为每种 ContactType 编写边界用例,例如:
    • PHONENUMBER: "1234567890" ✅,"123abc" ❌,"" ❌
    • EMAIL: "test@example.com" ✅,"invalid@.com" ❌,"user+tag@domain.co.uk" ✅

? 总结

通过将格式规则内聚于枚举,不仅消除了外部 switch 的重复校验逻辑,还提升了代码可读性与可扩展性。当业务需要新增联系方式类型时,只需扩展枚举并提供对应正则,无需修改任何 DTO 或服务层代码——真正实现“开闭原则”。

相关文章

驱动精灵
驱动精灵

驱动精灵基于驱动之家十余年的专业数据积累,驱动支持度高,已经为数亿用户解决了各种电脑驱动问题、系统故障,是目前有效的驱动软件,有需要的小伙伴快来保存下载体验吧!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

231

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

435

2024.03.01

switch语句用法
switch语句用法

switch语句用法:1、Switch语句只能用于整数类型,枚举类型和String类型,不能用于浮点数类型和布尔类型;2、每个case语句后面必须跟着一个break语句,以防止执行其他case的代码块,没有break语句,将会继续执行下一个case的代码块;3、可以在一个case语句中匹配多个值,使用逗号分隔;4、Switch语句中的default代码块是可选的等等。

528

2023.09.21

Java switch的用法
Java switch的用法

Java中的switch语句用于根据不同的条件执行不同的代码块。想了解更多switch的相关内容,可以阅读本专题下面的文章。

409

2024.03.13

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

253

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

206

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1463

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

615

2023.11.24

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

25

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2.4万人学习

C# 教程
C# 教程

共94课时 | 6.4万人学习

Java 教程
Java 教程

共578课时 | 44.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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