DTD 是定义 XML 文档结构合法性的语法规则,分内部(嵌入文档开头)和外部(独立 .dtd 文件)两种声明方式,支持元素嵌套顺序、内容类型、属性及实体声明,需配合专用工具验证,适用于轻量或遗留系统。

DTD 是 Document Type Definition(文档类型定义)的缩写,本质是一套语法规则,用来定义 XML 文档中允许出现哪些元素、它们的嵌套顺序、内容类型、属性要求等。它不描述数据含义,而是约束文档结构是否“合法”——形式良好的 XML 只保证语法正确;加上 DTD 验证后,才能称为“有效 XML”。
DTD 的核心作用
它让 XML 文档自带格式说明书,便于不同系统之间统一理解数据结构。比如两个部门约定用同一份 DTD,就能确保各自生成的订单 XML 都包含 orderID、product、quantity 且顺序一致,避免解析失败。
内部 DTD 声明方式
把 DTD 定义直接写在 XML 文件开头,用 ... ]> 包裹:
- 必须放在 XML 声明(如 )之后、根元素之前
- 方括号内写元素声明,例如: 表示 note 下必须按此顺序包含这四个子元素
- 每个子元素需单独声明内容类型,如 表示 to 只能含纯文本
- 支持实体声明,如 2025">,之后可用 ©right; 引用
外部 DTD 声明方式
把 DTD 单独存为 .dtd 文件(如 book.dtd),XML 中只保留引用语句:
- 语法为:,路径可为相对或绝对 URL
- 外部 DTD 文件里不带 ,只写声明内容,例如:
- 多个 XML 文件可共用同一个 DTD,修改一处即同步生效,适合标准化场景
- 注意编码一致性:若 DTD 文件含中文,需确保其保存为 UTF-8,且 XML 声明中指定 encoding="UTF-8"
验证与使用提示
浏览器通常不执行 DTD 验证,需借助专门工具(如 xmllint、Oxygen XML Editor)或编程语言中的 XML 解析器(如 Java 的 DocumentBuilder、Python 的 xml.etree.ElementTree 配合 DTD 加载)来校验。
- 声明了 DTD 但未满足规则时,解析会报错,例如子元素缺失、顺序错乱、标签大小写不符
- 内部 DTD 适合简单、单次使用的文档;外部 DTD 更适合团队协作或长期维护的 XML 标准
- 虽然现代项目多用 XSD 替代 DTD(因支持命名空间、数据类型更丰富),但在嵌入式设备、老旧系统或轻量配置文件中,DTD 仍常见且实用









