最近在用.NET做一个Java软件的接口,其中开发过程中涉及不少对Xml文档的操作,借助微软的MSDN和自己的使用经验,现简单介绍一下ASP.NET中对XML文档的操作。\n
\n\n
一、 XML文档\n
\n\n
我们大家都知道,XML是”Extensible Markup Language”的缩写,即可扩展标记语言。它是Internet环境中跨平台的、依赖于内容的技术,是这个时代中处理分布式结构信息的选择工具。在W3C组织领导下的工作小组发展并支持XML技术,使用它来简化通过Internet的文档信息传输。
\n
XML文档分为两类:有效的XML文档以及简化格式的XML文档。
\n
一个简化格式的XML文档必须遵从下面几个原则:
\n
l 至少有一个元素
\n
l 遵守XML规范
\n
l 根元素(比如上面例子中的<Mail>)应该不被其他元素所包含
\n
l 适当的元素嵌套是必须的
\n
l 属性值应该在问号内
\n
l 除了保留实体外,所有的实体都要声明
\n
有效XML
\n
有效XML文档指的是那些拥有一个DTD参考文件的XML文档。一个有效XML文档至少必须首先是简化格式的XML文档。跟随这个文档的DTD文件的有效性促进了XML执行程序的运行以及文档在兼容XML浏览器中的显示。
\n
XML文档举例
\n
例子1 – 一个简化格式的XML文档:
\n
<?xml version=”1.0″ standalone=”no”?>
\n
<Mail>
\n
<From>Author</From>
\n
<To>Receiver</To>
\n
<Date> Thu, 7 Oct 1999 11:15:16 -0600</Date>
\n
<Subject>XML Introduction</Subject>
\n
<body><p>Thanks for reading<Br/>
\n
this article</p>
\n
<br/>
\n
<p>Hope you enjoyed this article</p>
\n
</body>
\n
</Mail>
\n
第1行是XML声明,其中version属性指明了XML的版本,standalone属性等于”no”表示标记声明不独立于文档内部。XML声明可以看做是”运行指令”。尽管这个声明不是必须的,但是最好包含它,这将提高文档的灵活性。
\n
例子2 – 一个遵守mail.dtd文件的有效XML文档。Date元素被省略,因为在mail.dtd中它是可选的。 元素 P 具有justify属性。Body和P元素间是Comments文本:
\n
<?xml version=”1.0″ standalone=”no”?>
\n
<!DOCTYPE Mail system “http://infowest.com/DTDS/mail.dtd”>
\n
<Mail>
\n
<From>Author</From>
\n
<To>Receiver</To>
\n
<Cc>Receiver2</Cc>
\n
<Subject>XML Introduction</Subject>
\n
<body>Comments:<p align=”justify”>Thanks for reading<Br/>
\n
this article</p>
\n
<br/>
\n
<p>Hope you enjoyed this article</p>
\n
</body>
\n
</Mail>
\n
例子3 -一个遵守mail.dtd文件的有效XML文档,存在Date 元素和Cc 元素,P元素拥有属性right:
\n
<?xml version=”1.0″ standalone=”no”?>
\n
<!DOCTYPE Mail system “http://infowest.com/DTDS/mail.dtd”>
\n
<Mail>
\n
<From>Author</From>
\n
<To>Receiver</To>
\n
<Cc>Receiver2</Cc>
\n
<Date> Thu, 7 Oct 1999 11:15:16 -0600</Date>
\n
<Subject>XML Introduction</Subject>
\n
<body>Comments:<p align = “right” >Thanks for reading<Br/>
\n
this article</p>
\n
<br/>
\n
<p>Hope you enjoyed this article</p>
\n
</body>
\n
</Mail>
\n
XML 文档可以含有注释信息,注释的语法与HTML相似。除了”–”字符串外,任何文本信息都可以放置在标记<– 和 –>之间。处理指令PI(Processing instruction)可以嵌入到文档中, PI的数据成分可以被处理进程所识别。
\n
创作者也许希望包含一些不被解析器解析的代码。这些代码可以放置到忽略代码段中。可忽略的代码段具备如下的语法:
\n
<[CDATA[被忽略的文字信息]]>
\n
简言之,忽略代码段要以<[CDATA[ and end with ]]> 开始。
\n
二、 ASP.NET对XML文档的操作
\n
在对XML文档有一定的基础了解后,我们再来看一下ASP.NET中对XML文档操作最常用的类——XmlDocument。它使用起来非常容易,XmlDocument 其实就是一个简单的树。
\n
使用类XmlDocument之前,我们须引用命名空间System.Xml。
\n
下面我们来看一下,对Xml文件添加的结点的代码:
\n
\n
\n
\n
\n
\n
\n
第37行代是加载已定义的Xml文档,XmlDocument有两种加载Xml文档的方法,Load()方法加载指定的 XML 数据,LoadXml()方法从指定的字符串加载 XML 文档。
\n
XmlNode表示 XML 文档中的单个节点。
\n
下面我们再来看一段删除结点的程序:
\n
\n
\n
\n
这些都是对Xml文档结点的操作,下面我们再来看一下如何访问Xml文档中的各结点。
\n
XmlDocument Doc_Detail = new XmlDocument();
\n
Doc_Detail.Load (Server.MapPath(“XmlFile.Xml”));
\n
\n
XmlNode Node1 = Doc_Detail.SelectSingleNode(“vlink/object”);
\n
XmlNodeList Node2 = Node1.SelectNodes(“member”);
\n
\n
Hashtable tb = new Hashtable();
\n
for (int j = 0; j < Node2.Count; j++)
\n
{
\n
switch(Node2[j].SelectSingleNode(“name”).InnerText.ToString())
\n
{
\n
case “blackPhoneNumber”:
\n
{
\n
string BlackPhoneNum = Node2[j].SelectSingleNode(“value”).SelectSingleNode(“string”).InnerText.ToString();
\n
tb.Add(“BlackPhoneNum”, BlackPhoneNum);
\n
break;
\n
}
\n
case “reason”:
\n
{
\n
string Reason = Node2[j].SelectSingleNode(“value”).SelectSingleNode(“string”).InnerText.ToString();
\n
tb.Add(“Reason”, Reason);
\n
break;
\n
}
\n
case “active”:
\n
{
\n
string Active = Node2[j].SelectSingleNode(“value”).SelectSingleNode(“boolean”).InnerText.ToString();
\n
tb.Add(“Active”, Active);
\n
\n
break;
\n
}
\n
}
\n
}
\n
这段代码实现了将一个Xml文档转化为HashTable结构的数据集。
这些只是ASP.NET中对Xml文档操作的一小部分功能,ASP.NET 2.0提供操作XML文档的功能是相当强大的,希望大家看了这篇文章后能得到点启发。来源:网易学院\n