0

0

XML的unparsed entity怎么引用?

幻夢星雲

幻夢星雲

发布时间:2025-07-29 16:11:01

|

801人浏览过

|

来源于php中文网

原创

非解析实体通过属性引用外部资源,解析器不解析其内容,仅将uri和类型传递给应用程序;2. 使用非解析实体的核心在于通过notation实现类型化引用,提供比直接使用url更丰富的语义信息;3. 与解析实体不同,非解析实体不参与xml内容解析,仅作为外部资源的强类型化指针,适用于多媒体集成、非xml文档引用及高可靠性数据交换场景。

XML的unparsed entity怎么引用?

XML的非解析实体(unparsed entity)引用,说白了,你不是直接在XML文档内容里“解析”它,而是通过一个元素的属性来“指向”它。XML解析器不会去处理这个实体的内容,它只是把这个实体的URI和它的类型信息(notation)传递给应用程序,让应用程序自己去搞定。这就像是给你的程序一个线索,告诉它“这里有个外部文件,长这样,你看着办吧。”

解决方案

要引用一个非解析实体,你需要在XML的文档类型定义(DTD)中完成两步:先声明一个“记号”(notation),再声明这个非解析实体本身。最后,在你的XML文档中,通过一个特定类型的属性来引用它。

第一步:声明一个记号(Notation)

记号是用来描述外部非XML数据格式的。它告诉应用程序这个实体是什么类型的数据(比如JPEG图片、PDF文档、或者某个特定应用的数据格式)。


这里,jpegpdf是记号的名字,SYSTEM "..."后面通常是MIME类型或一个外部标识符,用于帮助应用程序识别数据类型。

第二步:声明非解析实体

现在,你可以声明你的非解析实体了。声明时,你需要指定它的名字、它指向的外部资源(URI),以及它所关联的记号。


myCoverImageannualReport是实体的名字。SYSTEM "..."指向实际的文件路径。NDATA jpegNDATA pdf就是将这些实体分别与前面声明的jpegpdf记号关联起来。

第三步:在XML文档中引用

非解析实体不能像解析实体那样用&entityName;的方式直接插入到XML内容中。它们必须作为某个元素的属性值来引用。但这个属性本身也得在DTD中声明为ENTITY类型。


这里,我们声明了一个book元素,它有两个属性coverImagereportLink,它们的类型都是ENTITY。这意味着这些属性的值必须是已声明的非解析实体的名字。

最后,在你的XML文档中这样使用:


 

    XML探险记
    张三
    ...

当XML解析器处理到时,它会识别出coverImage是一个ENTITY类型的属性,并且其值myCoverImage是一个非解析实体。解析器不会去读取images/cover.jpg的内容,它只会将myCoverImage这个实体的URI(images/cover.jpg)和它关联的记号(jpeg)传递给处理这个XML文档的应用程序。应用程序拿到这些信息后,就知道要去加载images/cover.jpg这个JPEG图片文件并进行相应的处理。

为什么我们需要使用XML的非解析实体(Unparsed Entity)?

这其实是个挺有意思的设计。你可能会想,我直接在XML属性里写个URL不就行了吗?比如,多简单。但非解析实体提供的,远不止一个简单的URL链接那么粗暴。

虎课网
虎课网

虎课网是超过1800万用户信赖的自学平台,拥有海量设计、绘画、摄影、办公软件、职业技能等优质的高清教程视频,用户可以根据行业和兴趣爱好,自主选择学习内容,每天免费学习一个...

下载

在我看来,它的核心价值在于“类型化”和“语义丰富性”。当你只给一个URL时,应用程序并不知道这个URL指向的是图片、PDF、还是一个视频。它需要额外的逻辑去猜测或者依赖文件扩展名。而通过非解析实体,结合NDATANOTATION,我们是在DTD层面就给这个外部资源打上了一个明确的“类型标签”。这个标签(notation)可以非常具体,比如“这是一个JPEG图片”,或者“这是一个特定版本的CAD图纸文件”。

这使得XML文档不仅仅是数据的容器,更是外部资源管理的一个协调者。XML解析器虽然不碰外部数据本身,但它能确保你的XML文档中引用的外部资源是“合法”的,并且能向应用程序传递足够的信息,让应用程序知道如何正确地处理这些外部数据。这在那些需要严格验证和多媒体集成的场景下,比如早期的文档发布系统或者复杂的行业数据交换标准中,显得尤为重要。它提供了一种基于DTD的、强类型化的外部资源引用机制,确保了数据的一致性和可预测性。

非解析实体(Unparsed Entity)与解析实体(Parsed Entity)的核心差异在哪里?

这个问题触及了XML实体机制的本质区别。说白了,它们俩虽然都叫“实体”,但骨子里干的活儿完全不一样。

解析实体 (Parsed Entity),顾名思义,是XML解析器会“解析”其内容的实体。当XML解析器遇到一个解析实体引用(比如©rightInfo;),它会做一件事:把这个引用替换成实体声明中定义的内容,然后继续解析替换后的内容。这就像一个文本宏,解析器会把它展开。

  • 内容类型: 必须是XML解析器能够处理的文本内容,可以是内部定义的字符串,也可以是外部的XML或纯文本文件(但XML解析器会尝试将其作为XML片段来处理)。
  • 引用方式: 通常使用&entityName;的形式,出现在XML文档的内容区域或属性值中。
  • 解析行为: XML解析器会读取实体内容,并将其整合到主文档的解析流中。如果内容是XML,它会被解析;如果是非XML文本,它会被视为字符数据。

非解析实体 (Unparsed Entity),则完全是另一回事。它指向的是XML解析器“不解析”的内容,通常是外部的、非XML格式的二进制数据或者其他应用程序特有的数据。

  • 内容类型: 任何外部数据,包括图片(JPEG, PNG)、音频、视频、PDF文档,或者任何不符合XML语法的文本文件。XML解析器根本不关心其内部结构。
  • 引用方式: 只能通过一个属性来引用,而且这个属性必须在DTD中声明为ENTITY类型。你不能在XML内容里直接写&myImageEntity;来引用它。
  • 解析行为: XML解析器不会读取或解析非解析实体的内容。它只会识别出实体名称,获取其关联的URI和记号(notation),然后将这些信息传递给处理XML文档的应用程序。应用程序收到这些信息后,才负责根据URI去加载外部数据,并根据记号来决定如何处理这些数据(比如用图片查看器打开,或者用PDF阅读器打开)。

所以,最核心的差异在于:解析实体是XML文档的“内容扩展”,它们的内容是XML解析过程的一部分;而非解析实体则是XML文档的“外部资源引用”,它们的内容是应用程序的责任,XML解析器只是一个信息传递者。

在实际应用中,如何有效地利用XML的非解析实体?

虽然在现代XML应用中,特别是那些基于XML Schema(XSD)而非DTD的项目里,非解析实体可能不像过去那么常见,但它在特定场景下依然有着不可替代的价值。我个人觉得,理解它的设计哲学,对我们理解XML的“元数据”能力很有帮助。

1. 多媒体和二进制资源的集成: 这是非解析实体最经典、也最直观的应用场景。想象一下,你正在构建一个XML文档来描述一本电子书。这本书里有封面图片、章节插图、甚至一些嵌入的音频或视频片段。你当然可以在XML里直接写,但这只是一个URI。如果你的应用程序需要知道这个image.jpg是JPEG格式还是PNG格式,或者需要特定的处理方式,非解析实体就能派上用场。







    XML实战
    

在这里,coverImage="cover"不仅仅指向一个文件,它还通过DTD告诉应用程序:“嘿,这个cover实体,它是一个JPEG图片!”应用程序就能据此调用正确的图像处理模块。

2. 引用非XML格式的外部文档: 除了多媒体,很多时候我们需要在XML中引用其他格式的文档,比如一份PDF报告、一个Excel电子表格、或者一个CAD设计文件。这些文件本身不是XML,也不应该被XML解析器处理。非解析实体提供了一个干净的引用机制。







    第三季度预算报告已完成。

这使得你的XML文档可以作为不同类型信息的“总目录”或“清单”,而无需将所有数据都塞进XML格式。

3. 强类型化外部资源: 这点其实是前面两点的基础。非解析实体通过NDATANOTATION机制,为外部资源提供了一种强类型化的声明。这对于需要严格验证和互操作性的系统非常重要。例如,在航空航天或医疗领域的数据交换中,一个XML文档可能需要引用特定格式的传感器数据文件或医学影像。通过非解析实体,你可以确保引用的文件类型是符合预期的,从而提高数据的可靠性和系统的健壮性。

然而,值得一提的是,非解析实体是DTD特有的功能。在基于XML Schema(XSD)的现代XML应用中,由于XSD没有直接等同于NDATANOTATION的机制来声明外部非XML数据的类型,通常会采用xs:anyURI类型结合自定义属性(例如type="image/jpeg")来达到类似的目的。但这需要应用程序自己去解析这些自定义属性,而不是像DTD那样在解析器层面就提供类型提示。所以,如果你还在使用DTD,或者处理一些老旧但依然重要的XML标准,非解析实体依然是一个非常具体且有效的解决方案。

相关专题

更多
数据类型有哪几种
数据类型有哪几种

数据类型有整型、浮点型、字符型、字符串型、布尔型、数组、结构体和枚举等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

306

2023.10.31

php数据类型
php数据类型

本专题整合了php数据类型相关内容,阅读专题下面的文章了解更多详细内容。

222

2025.10.31

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1892

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2087

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1028

2024.11.28

mysql标识符无效错误怎么解决
mysql标识符无效错误怎么解决

mysql标识符无效错误的解决办法:1、检查标识符是否被其他表或数据库使用;2、检查标识符是否包含特殊字符;3、使用引号包裹标识符;4、使用反引号包裹标识符;5、检查MySQL的配置文件等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

182

2023.12.04

Python标识符有哪些
Python标识符有哪些

Python标识符有变量标识符、函数标识符、类标识符、模块标识符、下划线开头的标识符、双下划线开头、双下划线结尾的标识符、整型标识符、浮点型标识符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

280

2024.02.23

java标识符合集
java标识符合集

本专题整合了java标识符相关内容,想了解更多详细内容,请阅读下面的文章。

255

2025.06.11

Java编译相关教程合集
Java编译相关教程合集

本专题整合了Java编译相关教程,阅读专题下面的文章了解更多详细内容。

5

2026.01.21

热门下载

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

精品课程

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

共142课时 | 5.7万人学习

XQuery 教程
XQuery 教程

共12课时 | 3.6万人学习

XLink  教程
XLink 教程

共7课时 | 1.1万人学习

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

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