0

0

如何为自己的XML格式编写一个DTD

星降

星降

发布时间:2026-01-01 11:04:06

|

341人浏览过

|

来源于php中文网

原创

DTD是XML早期约束机制,现基本被XSD或Relax NG取代;仅适用于简单配置验证、老旧系统兼容或教学场景。

如何为自己的xml格式编写一个dtd

DTD 是什么,现在还该用吗

DTD(Document Type Definition)是 XML 最早的约束机制,用来声明元素、属性、嵌套规则和默认值。但它不支持命名空间、数据类型校验弱、语法独立于 XML 本身,现代项目基本被 XSDRelax NG 取代。如果你只是要快速验证简单配置文件、配合老旧系统(比如某些 Java SAX 解析器或遗留文档工具),或者教学演示,写 DTD 仍可行;否则建议直接跳过,改用 XSD。

从一个 XML 示例反推 DTD 声明

假设你有如下 XML 文件 book.xml




  Design Patterns
  Gamma et al.
  1994

要为它写 DTD,核心是还原三类声明:!ELEMENT(元素结构)、!ATTLIST(属性)、!ENTITY(可选,实体)。注意顺序:DTD 中 !ELEMENT 必须先于 !ATTLIST 引用该元素。

  • 包含三个子元素且顺序固定 → 写成
  • id 属性是必需的字符串 →
  • 每个子元素都是纯文本(#PCDATA),无子元素 → (同理 author/year)
  • 如果 year 只允许数字,DTD 无法校验,只能靠应用层处理

常见坑:括号语法、内容模型与特殊字符

DTD 的内容模型容易写错,尤其混合型或可选内容。例如:

SiteDynamic企业网站管理系统1.7.7 标准版
SiteDynamic企业网站管理系统1.7.7 标准版

SiteDynamic企业网站管理系统采用较为成熟的ASP+ACCESS编写,是迄今为止国内较先进的ASP语言企业网站管理系统。系统为企业级网站提供一个框架,能满足企业的基本应用,同时系统开放全部源码,用户可以根据自己的需求扩展出自己需求的模块,如:单页面、新闻、产品展示、下载、友情链接、电子商务、广告、会员、在线支付、人才招聘等。整套系统的设计构造,完全考虑大中小企业类网站的功能要求,网站的后台

下载
  • 允许 为空或含文本 → 必须写 ,不是 EMPTY(那是完全不能有内容)
  • 子元素可重复 0 次或多次 → 用 *,如 (author+) 表示至少一个 author(author*) 表示零个或多个
  • 元素可选且顺序不固定 → DTD 不支持,只能用 (author|title|year)*(但会允许任意混排,无法保证“最多一个 title”)
  • 在 DTD 文件里写 & 会解析失败 → 必须用 zuojiankuohaophpcn&(和 XML 一样)

如何让解析器真正加载并校验 DTD

光有 .dtd 文件不够,XML 声明里的 DOCTYPE 必须指向它,且解析器需开启外部 DTD 加载和校验。例如 Python 的 xml.etree.ElementTree 默认不校验,要用 lxml

from lxml import etree
parser = etree.XMLParser(dtd_validation=True)
tree = etree.parse("book.xml", parser)

Java 中需设置 SAXReader.setEntityResolver() 并启用 http://apache.org/xml/features/validation/dtd浏览器则完全忽略外部 DTD(出于安全限制)。另外,若 DTD 放在本地,SYSTEM "book.dtd" 路径必须相对于 XML 文件位置,不是 Python 脚本位置。

真实项目里,DTD 的路径管理、网络加载阻塞、缺乏类型提示,会让维护成本远高于收益。除非协议强制要求,否则别把它当首选方案。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

716

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

626

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

739

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

617

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1236

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

547

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

575

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

699

2023.08.11

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 0.6万人学习

Django 教程
Django 教程

共28课时 | 2.6万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.0万人学习

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

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