由于XML的易共享性等众多优点,XML技术越 来越多地被应用于企业数据处理等领域,如应用于企业报表、新闻发 布、会计数据处理等等。
XML正快速成为从中间层传送 数据到桌面的工具,由于XML的数据可以通过中间层代理与多种后 端(数据库)源集成,目前绝大多数数据库制造商已全面支持XML 技术,提供了各种强大功能处理XML数据。
Micro soft的.NET围绕XML这一核心提供了一个强大而快速的开 发工具——C#,它具有前所未有的高开发效率,特别是在XML编 程方面。
C#提供了许多相关类处理XML数据,如处理 stream的类: XmlReader和XmlWriter; DOM的类:XmlNode、XmlDocument和Xml Element等;
Xpath的类:XmlNavigator ;XSLT的类:XslTransform。
显示XM L文件内容
用C#编程实现显示XML文件中信息的方法 是使用.NET提供的标准类把XML文件内容读入一个Strea mReader类对象中,再用XmlDataDocument类 的DataSet读XML的方法去读XML信息到DataSet 中,DataSet再以DataView的方式赋给一个Web Form上的DataGrid,最后由DataBind显示数据 ,具体实现代码如下:
using System.Xml;
//处理XML必须加的Namespace,还需在Refere nces中加System.XML.Dll
us ing System.IO;
//读XML文 件必须加的Namespace
然后在Page_Load中加 入如下代码:
protected void Page_Load(objec t sender, EventArgs e){
string datafile="
guest. xml"
;
//假设XML文件名 为guest.xml
StreamReader tyj=new StreamReader(Server.M apPath(datafile));
XmlD ataDocument datadoc = new XmlD ataDocument();
//创建该对象 为了读取XML
datadoc.DataSet .ReadXml(tyj);
//读取gues t.xml文件内容
DataGrid1.Dat aSource = datadoc.DataSet.Tabl es[0].DefaultView;
//设置 DataGrid数据源
DataGrid1.D ataBind();
//绑定
datadoc=null ;
//释放资源< br>
tyj.Close();
}
// 释放StreamReader类,这非常重要,否则下次打开会显 示文件已经被使用
对应于显示用的Web Form中Dat aGrid的功能,我们需要增加下面的函数:
protected void OnSelectName(object sender,Ev entArgs e) {
Session[&q uot;
select_name"
]=(string )DataGrid1.SelectedItem.Cells[ 1].Text.ToString();
//把 选定的 DataGrid某行中的一个单元中的值(Name)存 入一个会话变量中,以便下一页用
Respons e.Redirect("
xml_manage.as px"
);
}
//转到有增加删除功 能的管理页
< br>
Web Form加入以下代码:
<
asp:DataG rid id=DataGrid1 runat="server " onselectedindexchanged="OnSe lectName" >
<
prop erty name="Columns">
<
asp:buttoncolumn Text="选择 " commandname="Select" />
<
/property>
< br>
代码的作用 是当按了“选择”按钮后,执行OnSelectName()中的 程序,把选定的 DataGrid中某行中的一个单元中的值(N ame)存入一个会话变量中,然后转到下一页。
增加X ML文件内容
在Web Form中增加相应的几个Te xtBox和一个用于提交的Button,如本文附图所示,并为 这button增加如下代码:
string datafile = &quo t;
guest.xml"
;
XmlDocument xmldocument = new XmlDocument ()
;
xmldocument.Lo ad(Server.MapPath(datafile)) ;
//把guest.xml读到xmldocu ment中
DocumentNavigator navigator = new DocumentNavig ator(xmldocument) ;
//最 重要的类
navigator.MoveToDo cumentElement() ;
navig ator.Insert(System.Xml.TreePos ition.FirstChild, XmlNodeType. Element, "
Guest"
,&qu ot;
"
,"
"
)
;
/ /插入节点Guest
navigator.In sert(System.Xml.TreePosition.F irstChild, XmlNodeType.Element , "
Name"
,"
" ;
,"
"
)
;
n avigator.Insert(System.Xml.Tre ePosition.FirstChild, XmlNodeT ype.Text,"
Name"
,&quo t;
"
,"
"
)
;
navigator.Value=Name.Tex t ;
//为该节点赋值
na vigator.MoveToParent() ;
< br>//返回父节点 Guest
……
//使用同类语句,在元素Name下插入另一些元素如C ountry、E-mail地址和留言等
xml document.Save(Server.MapPath(d atafile));
//最后保存这个XML文 档
navigator=null ;
< br>xmldocument=null ;
//释放XML文档,这样其他程序可以用它
< br>
上述代码使用Docume ntNavigator类增加元素和内容,注意使用后要释放资源 。
删除XML文件内容
删除选定记录,对于你 上面选择的节点,下面代码可查找到该节点并清除选中的信息:
string d atafile = "
guest.xml" ;
;
XmlDocument xmldocu ment = new XmlDocument() ;
xmldocument.Load(Server.Ma pPath(datafile)) ;
//把 guest.xml读到xmldocument中
DocumentNavigator navigator = new DocumentNavigator(xmldocu ment) ;
navigator.MoveT oDocumentElement() ;
na vigator.Select("
/Guests/G uest[Name='"
+Session[&quo t;
select_name"
]+"
']& quot;
);
//参数是Xpath
< br>navigator.RemoveSelected();
//执行删除
xmldocu ment.Save(Server.MapPath(dataf ile));
//最后保存这个XML文档
navigator=null;
// 释放类
xmldocument=null ;
//释放XML文档,这样其他程序可以用它
如需将XML文件中所有信息清除,使用“navigator. RemoveChildren();
”语句即可实现。
结论
综上可知,C#编写XML应用程序不但快捷而且方 便,在编写ASP.NET数据库应用程序时,用XML文件替代一 些小的Table,能减少许多数据库存取连接,也能让其他网络程 序更易使用这些数据。
目前XML的主要瓶颈在于文件系 统的读出或写入,故应使用更多内存和缓存方式,如果信息量不是巨 大无比且修改量也较小,而浏览量巨大的话,使用XML方法将是很 好的选择;相反,如数据量巨大,应考虑使用支持XML的数据库, 无论你使用ADO+连接其他数据库,还是使用SQL serve r,C#中都有直接的类函数可让这些数据库中的信息直接和XML 交互访问。