XmlTextWriter创建XML文件(2)

发表于:2007-06-30来源:作者:点击数: 标签:
如下便是创建该XML文件所需的ASP .net 代码: <%@ Import Namespace="System.XML" %> <%@ Import Namespace="System.Text" %> <script language="C#" runat="server"> void Page_Load(object sender, EventArgs e) { // Create a new XmlTextWriter in
     如下便是创建该XML文件所需的ASP.net代码:
  
  <%@ Import Namespace="System.XML" %>
  <%@ Import Namespace="System.Text" %>
  <script language="C#" runat="server">
  void Page_Load(object sender, EventArgs e)
  {
  // Create a new XmlTextWriter instance
  XmlTextWriter writer = new
  XmlTextWriter(Server.MapPath("userInfo.xml"), Encoding.UTF8);
  
  // start writing!
  writer.WriteStartDocument();
  writer.WriteStartElement("userInfo");
  
  // Creating the <browserInfo> element
  writer.WriteStartElement("browserInfo");
  
  if (Request.UrlReferrer == null)
  writer.WriteElementString("urlReferrer", "none");
  else
  writer.WriteElementString("urlReferrer",
  Request.UrlReferrer.PathAndQuery);
  
  writer.WriteElementString("userAgent", Request.UserAgent);
  writer.WriteElementString("userLanguages",
  String.Join(", ", Request.UserLanguages));
  writer.WriteEndElement();
  
  // Creating the <visitInfo> element
  writer.WriteStartElement("visitInfo");
  writer.WriteAttributeString("timeVisited", DateTime.Now.ToString());
  writer.WriteElementString("ip", Request.UserHostAddress);
  writer.WriteElementString("rawUrl", Request.RawUrl);
  writer.WriteEndElement();
  
  writer.WriteEndElement();
  writer.WriteEndDocument();
  writer.Close();
  }
  
    首先我们要注意是否有导入System.Xml and System.Text命名空间,然后我们在Page_Load事件中创建一个XmlTextWriter对象实例,并且指定创建的XML文件保存为userInfo.xml文件和它的编码类型为UTF8(a translation of 16-bit unicode encoding into 8-bits),然后使用WriteStartElement(elementName)方法来创建嵌套了其他元素的元素,并以WriteEndElement()作为结束,此外,我们使用WriteElementString(elementName, textValue)方法来创建最底层即没有嵌套其他元素的元素。
  
  
  
    在浏览器窗口中输出XML文件
  
    先前的例子示范了如何使用XmlTextWriter对象创建xml文件以及把它保存为一个文件,这个文件可能是你所需要的,但是有时候,我们需要把创建的XML文件在浏览器上显示出来,这个时候,我们可以使用上例代码创建userInfo.xml文件,然后打开它,再使用Response.Write()把它输出,但是这种方法并不是很好。
  
    一个好的方法是立即把XmlTextWriter对象的结果显示在浏览器上,要实现这个功能非常地容易,只需要在上例的代码基础上修改一行代码就可以了,在XmlTextWriter的类构造器中,我们不指定为一个文件路径,而是指定为Response.OutputStream,以使ASP.NET程序直接输出XML流到浏览器中,而不是保存为一个文件,当然了,你还可以设定<@ Page ... >指令中的MIME类型为text/xml来实现同样的功能,但是我建议你不要用这种方法来实现,因为有些浏览器不认得该格式而把它当做html来解释(它将蕴藏所有的xml元素,并删除所有的空格)。
  
  
  
    下面列出了上例修改后的部分代码,修改过的代码将一些粗体显示:
  
  <@ Page ContentType="text/xml" %>
  <%@ Import Namespace="System.Xml" %>
  <%@ Import Namespace="System.Text" %>
  <script language="C#" runat="server">
  void Page_Load(object sender, EventArgs e)
  {
  // Create a new XmlTextWriter instance
  XmlTextWriter writer = new
  XmlTextWriter(Response.OutputStream, Encoding.UTF8);
  
  // start writing!
  ...
  }
  
  
    注意,尽管你访问的是asp.net Web页面,但是你查看该实例所看到的仅仅是XML文档,这个文档跟先前创建的XML文件是一样的,所不同的是,先前是保存为一个XML文件userInfo.xml。
  
  
  
    总结
  
    本文示范了在.NET Framework中如何使用System.Xml.XmlTextWriter类来创建XML文件,XmlTextWriter对象可以创建一个XML文件,并把它保存到指定位置,也可以直接以指定的流形式显示在浏览器上,在很多编码工作中,使用XmlTextWriter对象构建基于XML的程序会有很多的优势,其中主要有可以使代码更加简洁,更具可读性,同时不用担心输出的XML文件是否符合规范。
  
  
  

原文转自:http://www.ltesting.net