欢迎光临
我们一直在努力

Visual C#的Web XML编程-.NET教程,C#语言

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

由于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交互访问。

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