1、使用LINQ读取
使用Xdocument上的Load方法,能够快速的加载一个XML文档,而后使用LINQ对 加载XML文档进行查询或其余操做,这里仅简单偏历。因此,一旦查询一组元素有返回元素集,就能够使用一个简单的foreach循环访问每个元素。核心代码以下:html
/// <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)); } }
2、使用XmlReader构造函数
固然还能够经过使用带有URL的XmlReader.Create方法来完成操做,它使用的是一个XmlUrlResolver类的一个实例检测传入的URL,而后打开一个通向由该URL表明的XML文档流。为了指定阅读器上的设置,能够使用另外一个Create的重载,它也经过一个XmlReaderSetting实例完成这一目的。代码以下:web
/// <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 } } } }
3、实例代码下载
代码下载:函数
转:http://www.cnblogs.com/tjdxlmy/archive/2009/08/01/1536574.htmlspa