设为首页收藏本站language 语言切换
查看: 1272|回复: 0
收起左侧

Visual C#的Web XML编程

[复制链接]
发表于 2010-2-25 10:21:41 | 显示全部楼层 |阅读模式
<p >由于XML的易共享性等众多优点,XML技术越来越多地被应用于企业数据处理等领域,如应用于企业报表、新闻发布、会计数据处理等等。 <p >XML正快速成为从中间层传送数据到桌面的工具,由于XML的数据可以通过中间层代理与多种后端(数据库)源集成,目前绝大多数数据库制造商已全面支持XML技术,提供了各种强大功能处理XML数据。 <p >Microsoft的.NET围绕XML这一核心提供了一个强大而快速的开发工具——C#,它具有前所未有的高开发效率,特别是在XML编程方面。 <p >C#提供了许多相关类处理XML数据,如处理stream的类: XmlReader和XmlWriter; DOM的类:XmlNode、XmlDocument和XmlElement等; Xpath的类:XmlNavigator;XSLT的类:XslTransform。 <p ><ccid_nobr><b>显示XML文件内容</b></ccid_nobr><p >用C#编程实现显示XML文件中信息的方法是使用.NET提供的标准类把XML文件内容读入一个StreamReader类对象中,再用XmlDataDocument类的DataSet读XML的方法去读XML信息到DataSet中,DataSet再以DataView的方式赋给一个Web Form上的DataGrid,最后由DataBind显示数据,具体实现代码如下: <p ><ccid_nobr><table width="550" border="1" cellspacing="0" cellpadding="0" bordercolorlight = "black" bordercolordark = "#FFFFFF"><tr><td bgcolor="e6e6e6" class="code">using System.Xml;<br>//处理XML必须加的Namespace,还需在References中加System.XML.Dll<br>using System.IO; <br>//读XML文件必须加的Namespace          </td></tr></table></ccid_nobr><p >然后在Page_Load中加入如下代码:<p ><ccid_nobr><table width="550" border="1" cellspacing="0" cellpadding="0" bordercolorlight = "black" bordercolordark = "#FFFFFF"><tr><td bgcolor="e6e6e6" class="code">protected void Page_Load(object sender, EventArgs e){ <br>string datafile=&quot;guest.xml&quot; ; <br>//假设XML文件名为guest.xml<br>StreamReader tyj=new StreamReader(Server.MapPath(datafile));<br>XmlDataDocument datadoc = new XmlDataDocument(); <br>//创建该对象为了读取XML<br>datadoc.DataSet.ReadXml(tyj);<br>//读取guest.xml文件内容<br>DataGrid1.DataSource = datadoc.DataSet.Tables[0].DefaultView;<br>//设置DataGrid数据源<br>DataGrid1.DataBind();<br>//绑定<br>datadoc=null ; <br>//释放资源<br>tyj.Close();}<br>//释放StreamReader类,这非常重要,否则下次打开会显示文件已经被使用          </td></tr></table></ccid_nobr><p >对应于显示用的Web Form中DataGrid的功能,我们需要增加下面的函数: <p ><ccid_nobr><table width="550" border="1" cellspacing="0" cellpadding="0" bordercolorlight = "black" bordercolordark = "#FFFFFF"><tr><td bgcolor="e6e6e6" class="code">protected void OnSelectName(object sender,EventArgs e) {<br>Session[&quot;select_name&quot;]=(string)DataGrid1.SelectedItem.Cells[1].Text.ToString();<br>//把选定的 DataGrid某行中的一个单元中的值(Name)存入一个会话变量中,以便下一页用<br>Response.Redirect(&quot;xml_manage.aspx&quot;);} <br>//转到有增加删除功能的管理页          </td></tr></table></ccid_nobr><p >Web Form加入以下代码: <p ><ccid_nobr><table width="550" border="1" cellspacing="0" cellpadding="0" bordercolorlight = "black" bordercolordark = "#FFFFFF"><tr><td bgcolor="e6e6e6" class="code">&lt;aspataGrid id=DataGrid1 runat="server" onselectedindexchanged="OnSelectName" &gt;<br>&lt;property name="Columns"&gt;<br>&lt;asp:buttoncolumn Text="选择" commandname="Select" /&gt;<br>&lt;/property&gt;          </td></tr></table></ccid_nobr><p >代码的作用是当按了“选择”按钮后,执行OnSelectName()中的程序,把选定的 DataGrid中某行中的一个单元中的值(Name)存入一个会话变量中,然后转到下一页。 <p ><ccid_nobr><b>增加XML文件内容</b></ccid_nobr><p >在Web Form中增加相应的几个TextBox和一个用于提交的Button,如本文附图所示,并为这button增加如下代码:<p ><ccid_nobr><table width="550" border="1" cellspacing="0" cellpadding="0" bordercolorlight = "black" bordercolordark = "#FFFFFF"><tr><td bgcolor="e6e6e6" class="code">string datafile = &quot;guest.xml&quot; ;XmlDocument xmldocument = new XmlDocument() ;<br>xmldocument.Load(Server.MapPath(datafile)) ; <br>//把guest.xml读到xmldocument中<br>DocumentNavigator navigator = new DocumentNavigator(xmldocument) ;<br>//最重要的类<br>navigator.MoveToDocumentElement() ;<br>navigator.Insert(System.Xml.TreePosition.FirstChild, XmlNodeType.Element, &quot;Guest&quot;,&quot;&quot;,&quot;&quot;) ;//插入节点Guest<br>navigator.Insert(System.Xml.TreePosition.FirstChild, XmlNodeType.Element, &quot;Name&quot;,&quot;&quot;,&quot;&quot;) ;<br>navigator.Insert(System.Xml.TreePosition.FirstChild, XmlNodeType.Text,&quot;Name&quot;,&quot;&quot;,&quot;&quot;) ;<br>navigator.Value=Name.Text ; <br>//为该节点赋值<br>navigator.MoveToParent() ; <br>//返回父节点 Guest<br>……<br>//使用同类语句,在元素Name下插入另一些元素如Country、E-mail地址和留言等<br>xmldocument.Save(Server.MapPath(datafile));<br>//最后保存这个XML文档<br>navigator=null ;<br>xmldocument=null ; <br>//释放XML文档,这样其他程序可以用它     </td></tr></table></ccid_nobr><p >上述代码使用DocumentNavigator类增加元素和内容,注意使用后要释放资源。 <p ><ccid_nobr><b>删除XML文件内容 </b></ccid_nobr><p >删除选定记录,对于你上面选择的节点,下面代码可查找到该节点并清除选中的信息:<p ><ccid_nobr><table width="550" border="1" cellspacing="0" cellpadding="0" bordercolorlight = "black" bordercolordark = "#FFFFFF"><tr><td bgcolor="e6e6e6" class="code">string datafile = &quot;guest.xml&quot; ;<br>XmlDocument xmldocument = new XmlDocument() ;<br>xmldocument.Load(Server.MapPath(datafile)) ; <br>//把guest.xml读到xmldocument中<br>DocumentNavigator navigator = new DocumentNavigator(xmldocument) ;<br>navigator.MoveToDocumentElement() ;<br>navigator.Select(&quot;/Guests/Guest[Name='&quot;+Session[&quot;select_name&quot;]+&quot;']&quot;);<br>//参数是Xpath<br>navigator.RemoveSelected(); <br>//执行删除<br>xmldocument.Save(Server.MapPath(datafile));<br>//最后保存这个XML文档<br>navigator=null;<br>//释放类<br>xmldocument=null ; <br>//释放XML文档,这样其他程序可以用它          </td></tr></table></ccid_nobr><p >如需将XML文件中所有信息清除,使用“navigator.RemoveChildren();”语句即可实现。 <p ><ccid_nobr><b>结论</b></ccid_nobr><p >综上可知,C#编写XML应用程序不但快捷而且方便,在编写ASP.NET数据库应用程序时,用XML文件替代一些小的Table,能减少许多数据库存取连接,也能让其他网络程序更易使用这些数据。 <p >目前XML的主要瓶颈在于文件系统的读出或写入,故应使用更多内存和缓存方式,如果信息量不是巨大无比且修改量也较小,而浏览量巨大的话,使用XML方法将是很好的选择;相反,如数据量巨大,应考虑使用支持XML的数据库,无论你使用ADO+连接其他数据库,还是使用SQL server,C#中都有直接的类函数可让这些数据库中的信息直接和XML交互访问。<p >(责任编辑 <ccid_nobr>尤北</ccid_nobr>)                                 <p align="center"></p></p>
您需要登录后才可以回帖 登录 | 论坛注册

本版积分规则

QQ|Archiver|手机版|小黑屋|sitemap|鸿鹄论坛 ( 京ICP备14027439号 )  

GMT+8, 2025-4-10 15:49 , Processed in 0.060016 second(s), 24 queries , Redis On.  

  Powered by Discuz!

  © 2001-2025 HH010.COM

快速回复 返回顶部 返回列表