当前位置:首页 > Asp.Net对Xml文件的操作

Asp.Net对Xml文件的操作

点击次数:1021  更新日期:2010-12-26
\n

最近在用.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


\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