一、 XML文檔
我們大家都知道,XML是"Extensible Markup Language"的縮寫,即可延伸標記語言 (XML)。它是Internet環境中跨平台的、依賴於內容的技術,是這個時代中處理分布式結構資訊的選擇工具。在W3C組織領導下的工作小組發展並支援XML技術,使用它來簡化通過Internet的文檔資訊傳輸。
XML文檔分為兩類:有效XML文檔以及簡化格式的XML文檔。
一個簡化格式的XML文檔必須遵從下面幾個原則:
l 至少有一個元素
l 遵守XML規範
l 根項目(比如上面例子中的<Mail>)應該不被其他元素所包含
l 適當的元素嵌套是必須的
l 屬性值應該在問號內
l 除了保留實體外,所有的實體都要聲明
有效XML
有效XML文檔指的是那些擁有一個DTD參考檔案的XML文檔。一個有效XML文檔至少必須首先是簡化格式的XML文檔。跟隨這個文檔的DTD檔案的有效性促進了XML執行程式的運行以及文檔在相容XML瀏覽器中的顯示。
XML文檔舉例
例子1 - 一個簡化格式的XML文檔:
<?xml version="1.0" standalone="no"?>
<Mail>
<From>Author</From>
<To>Receiver</To>
<Date> Thu, 7 Oct 1999 11:15:16 -0600</Date>
<Subject>XML Introduction</Subject>
<body><p>Thanks for reading<Br/>
this article</p>
<br/>
<p>Hope you enjoyed this article</p>
</body>
</Mail>
第1行是XML聲明,其中version屬性指明了XML的版本,standalone屬性等於"no"表示標記聲明不獨立於文檔內部。XML聲明可以看做是"運行指令"。儘管這個聲明不是必須的,但是最好包含它,這將提高文檔的靈活性。
例子2 - 一個遵守mail.dtd檔案的有效XML文檔。Date元素被省略,因為在mail.dtd中它是可選的。 元素 P 具有justify屬性。Body和P元素間是Comments文本:
<?xml version="1.0" standalone="no"?>
<!DOCTYPE Mail system "http://infowest.com/DTDS/mail.dtd">
<Mail>
<From>Author</From>
<To>Receiver</To>
<Cc>Receiver2</Cc>
<Subject>XML Introduction</Subject>
<body>Comments:<p align="justify">Thanks for reading<Br/>
this article</p>
<br/>
<p>Hope you enjoyed this article</p>
</body>
</Mail>
例子3 -一個遵守mail.dtd檔案的有效XML文檔,存在Date 元素和Cc 元素,P元素擁有屬性right:
<?xml version="1.0" standalone="no"?>
<!DOCTYPE Mail system "http://infowest.com/DTDS/mail.dtd">
<Mail>
<From>Author</From>
<To>Receiver</To>
<Cc>Receiver2</Cc>
<Date> Thu, 7 Oct 1999 11:15:16 -0600</Date>
<Subject>XML Introduction</Subject>
<body>Comments:<p align = "right" >Thanks for reading<Br/>
this article</p>
<br/>
<p>Hope you enjoyed this article</p>
</body>
</Mail>
XML 文檔可以含有注釋資訊,注釋的文法與HTML相似。除了"--"字串外,任何文本資訊都可以放置在標記<-- 和 -->之間。處理指示PI(Processing instruction)可以嵌入到文檔中, PI的資料成分可以被處理進程所識別。
創作者也許希望包含一些不被解析器解析的代碼。這些代碼可以放置到忽略程式碼片段中。可忽略的程式碼片段具備如下的文法:
<[CDATA[被忽略的文字資訊]]>
簡言之,忽略程式碼片段要以<[CDATA[ and end with ]]> 開始
二、 ASP.NET對XML文檔的操作
在對XML文檔有一定的基礎瞭解後,我們再來看一下ASP.NET中對XML文檔操作最常用的類——XmlDocument。它使用起來非常容易,XmlDocument 其實就是一個簡單的樹。
使用類XmlDocument之前,我們須引用命名空間System.Xml。
下面我們來看一下,對Xml檔案添加的結點的代碼:
第37行代是載入已定義的Xml文檔,XmlDocument有兩種載入Xml文檔的方法,Load()方法載入指定的 XML 資料,LoadXml()方法從指定的字串載入 XML 文檔。
XmlNode表示 XML 文檔中的單個節點。
下面我們再來看一段刪除結點的程式:
這些都是對Xml文檔結點的操作,下面我們再來看一下如何訪問Xml文檔中的各結點。
XmlDocument Doc_Detail = new XmlDocument();
Doc_Detail.Load (Server.MapPath(“XmlFile.Xml”));
XmlNode Node1 = Doc_Detail.SelectSingleNode("vlink/object");
XmlNodeList Node2 = Node1.SelectNodes("member");
Hashtable tb = new Hashtable();
for (int j = 0; j < Node2.Count; j++)
{
switch(Node2[j].SelectSingleNode("name").InnerText.ToString())
{
case "blackPhoneNumber":
{
string BlackPhoneNum = Node2[j].SelectSingleNode("value").SelectSingleNode("string").InnerText.ToString();
tb.Add("BlackPhoneNum", BlackPhoneNum);
break;
}
case "reason":
{
string Reason = Node2[j].SelectSingleNode("value").SelectSingleNode("string").InnerText.ToString();
tb.Add("Reason", Reason);
break;
}
case "active":
{
string Active = Node2[j].SelectSingleNode("value").SelectSingleNode("boolean").InnerText.ToString();
tb.Add("Active", Active);
break;
}
}
}
這段代碼實現了將一個Xml文檔轉化為HashTable結構的資料集。
這些只是ASP.NET中對Xml文檔操作的一小部分功能,ASP.NET 2.0提供操作XML文檔的功能是相當強大的,希望大家看了這篇文章後能得到點啟發。