XML的基础和DOCTYPE字段的解析

转载 2015年11月20日 19:06:20
DTD——文档类型定义(Document Type Definition)/
由于XML可以自定义标签,那么自然各人编写的标签不一样,这样同步数据便成了问题,因为其它人不知道某个标签应该怎么用,表示什么意思.DTD就是为了解决此问题的!

DTD是一种保证XML文档格式正确的有效方法,可以比较XML文档和DTD文件来看文档是否符合规范,元素和标签使用是否正确。一个DTD文档包含:元素的定义规则,元素间关系的定义规则,元素可使用的属性,可使用的实体或符号规则。

DTD分为内部DTD与外部DTD,内部DTD包含在XML文档中,外部DTD则通过URL引用.一个DTD文件是以.dtd结尾的文本文件

在XML中引入DTD DOCTYPE 文档类型声明
内部DTD,可以将standalone设置成yes.

Xml代码
Java代码
  1. <?xml version="1.0" standalone="yes"?>     
  2. <!DOCTYPE root [      
  3. <!ELEMENT root EMPTY>     
  4. ]>    
  1. <?xml version="1.0" standalone="yes"?>    
  2. <!DOCTYPE root [     
  3. <!ELEMENT root EMPTY>    
  4. ]>    



外部DTD,需要将standalone设成no

Java代码
  1. <?xml version="1.0" standalone="no"?>     
  2. <!DOCTYPE root SYSTEM "http://www.test.org/test.dtd">   
  1. <?xml version="1.0" standalone="no"?>    
  2. <!DOCTYPE root SYSTEM "http://www.test.org/test.dtd">   


DOCTYPE分析
DTD声明始终以!DOCTYPE开头,空一格后跟着文档根元素的名称,如果是内部DTD,则再空一格出现[],在中括号中是文档类型定义的内容. 而对于外部DTD,则又分为私有DTD与公共DTD,私有DTD使用SYSTEM表示,接着是外部DTD的URL. 而公共DTD则使用PUBLIC,接着是DTD公共名称,接着是DTD的URL.下面是一些示例

公共DTD,DTD名称格式为"注册//组织//类型 标签//语言","注册"指示组织是否由国际标准化组织(ISO)注册,+表示是,-表示不是."组织"即组织名称,如:W3C; "类型"一般是DTD,"标签"是指定公开文本描述,即对所引用的公开文本的唯一描述性名称,后面可附带版本号。最后"语言"是DTD语言的ISO 639语言标识符,如:EN表示英文,ZH表示中文,在下面的地址有完整的ISO 639语言标识符列表[url]http://ftp.ics.uci.edu/pub/ietf/http/related/iso639.txt [/url]

Java代码
  1. <!DOCTYPE root SYSTEM "http://www.test.org/test.dtd">  
  1. <!DOCTYPE root SYSTEM "http://www.test.org/test.dtd">  

 


下面是XHTML 1.0 Transitional的DTD.以!DOCTYPE开始,html是文档根元素名称,PUBLIC表示是公共DTD,后面是DTD名称,以-开头表示是非ISO组织 组织名称是W3C,EN表示DTD语言是英语,最后是DTD的URL

Java代码
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"       
  2.     "http://www.w3.org/TR/xhtml/DTD/xhtml1-transitional.dtd">    
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"      
  2.     "http://www.w3.org/TR/xhtml/DTD/xhtml1-transitional.dtd">    




注意:虽然DTD的文件URL可以使用相对URL也可以使用绝对URL,但推荐标准是使用绝对URL.另一方面,对于公共DTD,如果解释器能够识别其名称,则不去查看URL上的DTD文件

org.xml.sax.SAXParseException: Document root element "beans", must match DOCTYPE root "null".

严重: Exception sending context initialized event to listener instance of class org.springframework.we...

org.xml.sax.SAXParseException: Document root element "beans", must match DOCTYPE root "null".

严重: Exception sending contextinitialized event to listener instance of class org.springframework.web...
  • lhy66
  • lhy66
  • 2011年04月20日 23:30
  • 4098

ANDROID的MANIFEST.XML文件字段解析

android:allowTaskReparenting 是否允许activity更换从属的任务,比如从短信息任务 切换到浏览器任务。 android:alwaysRetainTaskState ...

带参数的可执行jar包程序实现从指定位置读取xml并解析指定字段

1、需求描述:有一批包含表DDL信息的xml文件,结构相同,希望迅速读取其中的表结构信息 2、执行环境:Linux/UNIX 3、实现思路:新建一个java工程,主函数设置两个入参,一个是文件路径,一...

Oracle中通过:触发器,存储过程,Function调用实现解析Clob字段类型中存储的xml字符串

摘要:最近项目中用到了存储过程,触发器,Function,由于以前没怎么用过,所以...

Oracle存储过程中使用游标来批量解析CLOB字段里面的xml字符串:

摘要:之前在项目中使用到了Oracle数据库中通过触发器去调用存储过程执行数据解析并Update到对应的数据表中,但是,经过一段时间的测试使用发现,如果job那天停掉了,然后你再重新新建job的话,这...

SAX方式解析XML文件的方法分析,并取特定字段生成对象

SAX(Simple API for XML)SAX的工作原理简单地说就是对文档进行顺序扫描,当扫描到文档(document)开始与结束、元素(element)开始与结束、文档(document)结束...

了解浏览器解析模式:DOCTYPE声明问题

触发标准模式 1、加DOCTYPE声明,比如: 2、设置X-UA-Compatible触发。 触发怪异模式 1、无doctype声明、定义旧的HTML版本(HTML4以下,...
  • sou3713
  • sou3713
  • 2013年04月07日 10:28
  • 442
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:XML的基础和DOCTYPE字段的解析
举报原因:
原因补充:

(最多只允许输入30个字)