一、使用LINQ讀取
使用Xdocument上的Load方法,可以快速的加載一個XML文檔,然後使用LINQ對 加載XML文檔進行查詢或其他操作,這裡僅簡單偏歷。所以,一旦查詢一組元素有返回元素集,就可以使用一個簡單的foreach循環訪問每一個元素。核心代碼如下:
/// <summary>
/// 使用LINQ讀取web上的XML
/// </summary>
public static void UseLINQ()
{
string sURL = "http://localhost:9058/GameServerInfo/XMLFile.XML";
XDocument oXDoc = XDocument.Load(sURL);
var qurey = from e in oXDoc.Descendants()
where e.NodeType == XMLNodeType.Element
select new
{
ElementName=e.Name.ToString(),
ElementValue=e.Value
};
foreach(var elementInfo in qurey)
{
HttpContext.Current.Response.Write(string.Format("ElementName->{0} ElementValue->{1}<br />", elementInfo.ElementName, elementInfo.ElementValue));
}
}
二、使用XMLReader構造函數
當然還可以通過使用帶有URL的XmlReader.Create方法來完成操作,它使用的是一個XmlUrlResolver類的一個實例檢測傳入的URL,然後打開一個通向由該URL代表的XML文檔流。為了指定閱讀器上的設置,可以使用另一個Create的重載,它也通過一個XMLReaderSetting實例完成這一目的。代碼如下:
/// <summary>
/// 使用XMLReader構造函數
/// </summary>
public static void UseXMLReader()
{
string sURL = "http://localhost:9058/GameServerInfo/XMLFile.XML";
using(XmlReader read=XMLReader.Create(sURL))
{
while(read.Read())
{
switch (read.NodeType)
{
case XMLNodeType.Element:
HttpContext.Current.Response.Write(string.Format("ElementName->{0} <br />", read.Name));
break;
case XMLNodeType.Text:
HttpContext.Current.Response.Write(string.Format("ElementValue->{0}<br />", read.Value));
break;
case XMLNodeType.CDATA:
HttpContext.Current.Response.Write(string.Format("ElementValue->{0}<br />", read.Value));
break;
//other
}
}
}
}