Visual C#的Web XML编程

ZDNet软件频道 时间:2008-07-18 作者: |  我要评论()
本文关键词:网络编程 C# xml Windows
由于XML的易共享性等众多优点,XML技术越来越多地被应用于企业数据处理等领域,如应用于企业报表、新闻发布、会计数据处理等等。
由于xml的易共享性等众多优点,xml技术越来越多地被应用于企业数据处理等领域,如应用于企业报表、新闻发布、会计数据处理等等。

xml正快速成为从中间层传送数据到桌面的工具,由于xml的数据可以通过中间层代理与多种后端(数据库)源集成,目前绝大多数数据库制造商已全面支持xml技术,提供了各种强大功能处理xml数据。

Microsoft的.NET围绕xml这一核心提供了一个强大而快速的开发工具——C#,它具有前所未有的高开发效率,特别是在xml编程方面。

C#提供了许多相关类处理xml数据,如处理stream的类: xmlReader和xmlWriter; DOM的类:xmlNode、xmlDocument和xmlElement等; Xpath的类:xmlNavigator;XSLT的类:XslTransform。

显示xml文件内容

C#编程实现显示xml文件中信息的方法是使用.NET提供的标准类把xml文件内容读入一个StreamReader类对象中,再用xmlDataDocument类的DataSet读xml的方法去读xml信息到DataSet中,DataSet再以DataView的方式赋给一个Web Form上的DataGrid,最后由DataBind显示数据,具体实现代码如下:

using System.xml;
//处理xml必须加的Namespace,还需在References中加System.xml.Dll
using System.IO;
//读xml文件必须加的Namespace


然后在Page_Load中加入如下代码:

protected void Page_Load(object sender, EventArgs e){
string datafile="guest.xml" ;
//假设xml文件名为guest.xml
StreamReader tyj=new StreamReader(Server.MapPath(datafile));
xmlDataDocument datadoc = new xmlDataDocument();
//创建该对象为了读取xml
datadoc.DataSet.Readxml(tyj);
//读取guest.xml文件内容
DataGrid1.DataSource = datadoc.DataSet.Tables[0].DefaultView;
//设置DataGrid数据源
DataGrid1.DataBind();
//绑定
datadoc=null ;
//释放资源
tyj.Close();}
//释放StreamReader类,这非常重要,否则下次打开会显示文件已经被使用


对应于显示用的Web Form中DataGrid的功能,我们需要增加下面的函数:

protected void OnSelectName(object sender,EventArgs e) {
Session["select_name"]=(string)DataGrid1.SelectedItem.Cells[1].Text.ToString();
//把选定的 DataGrid某行中的一个单元中的值(Name)存入一个会话变量中,以便下一页用
Response.Redirect("xml_manage.aspx");}
//转到有增加删除功能的管理页


Web Form加入以下代码:

<asp:DataGrid id=DataGrid1 runat="server" onselectedindexchanged="OnSelectName" >
<property name="Columns">
<asp:buttoncolumn Text="选择" commandname="Select" />
</property>


代码的作用是当按了“选择”按钮后,执行OnSelectName()中的程序,把选定的 DataGrid中某行中的一个单元中的值(Name)存入一个会话变量中,然后转到下一页。

增加xml文件内容

在Web Form中增加相应的几个TextBox和一个用于提交的Button,如本文附图所示,并为这button增加如下代码:

string datafile = "guest.xml" ;xmlDocument xmldocument = new xmlDocument() ;
xmldocument.Load(Server.MapPath(datafile)) ;
//把guest.xml读到xmldocument中
DocumentNavigator navigator = new DocumentNavigator(xmldocument) ;
//最重要的类
navigator.MoveToDocumentElement() ;
navigator.Insert(System.xml.TreePosition.FirstChild, xmlNodeType.Element, "Guest","","") ;//插入节点Guest
navigator.Insert(System.xml.TreePosition.FirstChild, xmlNodeType.Element, "Name","","") ;
navigator.Insert(System.xml.TreePosition.FirstChild, xmlNodeType.Text,"Name","","") ;
navigator.Value=Name.Text ;
//为该节点赋值
navigator.MoveToParent() ;
//返回父节点 Guest
……
//使用同类语句,在元素Name下插入另一些元素如Country、E-mail地址和留言等
xmldocument.Save(Server.MapPath(datafile));
//最后保存这个xml文档
navigator=null ;
xmldocument=null ;
//释放xml文档,这样其他程序可以用它


上述代码使用DocumentNavigator类增加元素和内容,注意使用后要释放资源。

删除xml文件内容

删除选定记录,对于你上面选择的节点,下面代码可查找到该节点并清除选中的信息:

string datafile = "guest.xml" ;
xmlDocument xmldocument = new xmlDocument() ;
xmldocument.Load(Server.MapPath(datafile)) ;
//把guest.xml读到xmldocument中
DocumentNavigator navigator = new DocumentNavigator(xmldocument) ;
navigator.MoveToDocumentElement() ;
navigator.Select("/Guests/Guest[Name='"+Session["select_name"]+"']");
//参数是Xpath
navigator.RemoveSelected();
//执行删除
xmldocument.Save(Server.MapPath(datafile));
//最后保存这个xml文档
navigator=null;
//释放类
xmldocument=null ;
//释放xml文档,这样其他程序可以用它


如需将xml文件中所有信息清除,使用“navigator.RemoveChildren();”语句即可实现。

结论

综上可知,C#编写xml应用程序不但快捷而且方便,在编写ASP.NET数据库应用程序时,用xml文件替代一些小的Table,能减少许多数据库存取连接,也能让其他网络程序更易使用这些数据。

目前xml的主要瓶颈在于文件系统的读出或写入,故应使用更多内存和缓存方式,如果信息量不是巨大无比且修改量也较小,而浏览量巨大的话,使用xml方法将是很好的选择;相反,如数据量巨大,应考虑使用支持xml的数据库,无论你使用ADO+连接其他数据库,还是使用SQL server,C#中都有直接的类函数可让这些数据库中的信息直接和xml交互访问。
 

网络编程

C#

xml

Windows


百度大联盟认证黄金会员Copyright© 1997- CNET Networks 版权所有。 ZDNet 是CNET Networks公司注册服务商标。
中华人民共和国电信与信息服务业务经营许可证编号:京ICP证010391号 京ICP备09041801号-159
京公网安备:1101082134