欢迎光临
我们一直在努力

XmlTextWriter创建XML文件-.NET教程,XML应用

建站超值云服务器,限时71元/月

引言

  随着xml的普及以及在动态web应用程序中大量应用,如何通过.net创建,删除,修改xml文件变的也来也重要了。一个简单的概念是,xml文件跟大的文本文件并没有什么区别,同时它是先于.net出现,很多asp的开发者,当他需要程序输出xml文件的时候,通常都是用response.write()方法输出为xml文档。
  使用response.write()的方式来输出xml文档,并不是一种那么好的方法,首先,我们用这种方法输出字符以组成xml文件的时候,我们会很担心输出的这些字符是不是符合xml规范,不符合xml规范的xml文档将不能得到真确完整的显示,如:<,>,&””,和这些符号,当它们在xml文件里的出现的时候,我们必须手工查找这些不合规范的字符;再次,当我们需要输出的是一个包含很多名字空间,属性和元素的xml文件的时候,使用response.write()方法所必须的代码将会变得冗长以及可读性差。

  幸运的是,.net framework提供了一个特别为创建xml文件使用的类-system.xml.xmltextwriter,使用这个类来创建xml文件,你并不需要担心输出是否符合xml规范的问题,同时代码将会变得非常简洁。在这篇文章中,我们将深入的讲述如何使用xmltextwriter类来创建xml文件。

  关于xml的说明

  这篇文章假定读者具备一定的xml基础,如果你刚接触xml,我建议你在继续阅读本文之前,首先去看看“什么是xml”和“xml起步”这些资料。

  xmltextwriter对象简介:

  xmltextwriter对象包含了很多可用于在创建xml文件时添加元素和属性到xml文件里的方法,比较重要的有:

  writestartdocument()-创建xml文件首先就需要用到这个方法,它是在创建xml文件的第一行代码,用来指定该文件是xml文件以及设置它的编码类型;

  writestartelement(string)-这个方法的作用是在xml文件中创建新元素,你可以通过string参数设置元素的名称(当然了,你还可以使用optional关键字指定一个可选的参数);

  writeelementstring(name, text_value)-如果你需要创建一个除了字符,什么也没有的(如不嵌套元素)的元素,你可以使用该方法;

  writeendelement()-对应writestartelement(string)方法,作为一个元素的结尾;

  writeenddocument()-xml文件创建完成后使用该方法结束;

  close()-关闭所有的文本流,把创建的xml文件输出到指定位置。

  使用xmltextwriter对象创建xml文件,需要在类构造器中指定文件的类型,而且编码类型必须是system.text.encoding,如:system.text.encoding.ascii, system.text.encoding.unicode及system.text.encoding.utf8,在xmltextwriter类构造器指定为何种类型,在输出xml文件将以那种流文件形式输出。

  使用xmltextwriter对象创建一个简单的xml文件

  接下来,我们示范一下如何使用xmltextwriter对象来创建一个简单的xml文档,并把它保存到指定的位置,这个xml文件将包含访问该文件的用户的相关信息,它的输出格式如下:

 

<userinfo>
<browserinfo>
<urlreferrer>url referrer info</urlreferrer>
<useragent>user agent referrer info</useragent>
<userlanguages>languages info</userlanguages>
</browserinfo>
<visitinfo timevisited=”date/time the page was visited”>
<ip>visitors ip address</ip>
<rawurl>raw url requested</rawurl>
</visitinfo>
</userinfo>

  选用这个有这种结构的xml文件为输出对象,是为了可以在这里使用所有先前讲过的方法,方便阐述。

  如下便是创建该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文件是否符合规范。

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » XmlTextWriter创建XML文件-.NET教程,XML应用
分享到: 更多 (0)

相关推荐

  • 暂无文章