XML 在 ASP 环境下的应用(推荐)
2007-10-27 08:01
218 查看
2001年06月14日 13:32:00
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=3470
XML 在 ASP 环境下的应用(推荐) |
XML被誉为未来Web的生命所在。本文介绍如何在服务器端利用新的XML文档对象模型(DOM),通过ASP程序解析和应用XML数据。 一、文档对象模型 在服务器上解析和应用XML的能力为开发者打开了一个全新的世界。随着XML应用的日益广泛,在服务器上处理XML也变得更加重要。本文示范ASP应用在服务器端的XML文档处理过程,使用的XML例子是一个新闻文档。我们将介绍如何编写一个显示新闻文档日期和新闻数量的简单ASP页面,以及如何在ASP页面中显示新闻标题和相应的URL。 文档对象模型即Document Object Model,简称DOM。IE 5.0的XML文档对象模型提供了对W3C DOM核心规范(Level 1)所描述的编程接口的完整支持,同时它还支持一系列XML相关技术,比如XSL、XSL模式匹配、名称空间、数据类型等。DOM是XML解析器所导出的最基本的文档模型,它将XML文档描述为一个很容易导航和使用的树形结构。 W3C的DOM核心规范定义了两组DOM编程接口。第一组接口是编写处理和使用XML文档的应用时所必需的,第二组接口辅助开发者更轻松地处理XML文档。提供第二组接口只是为了方便,对于XML应用来说它们并不是必需的。 在ASP应用中,要在服务器上应用DOM是相当简单的,但服务器上必须安装IE 5.0,这是因为DOM的许多支持组件都是由IE提供的。安装好IE之后,只要在ASP应用中用类似下面的代码就可以创建DOM对象: >% Set objXML = Server.CreateObject("Microsoft.XMLDOM") %< 二、在服务器上处理XML(1) 在服务器上创建了DOM对象之后,我们既可以自己构造新的XML文档,也可以装载一个现有的文档。如果是装载现有文档,还可以选择是读取XML文本字符串,还是打开XML文档并装载其内容。在本文的例子中,我们假定服务器上已经有了一个最近新闻的XML文档mostRecentScriptingNews.xml。在装载XML文档之前,我们应该把DOM对象的async属性设置成“false”,这是告诉DOM对象装载XML文档不是异步进行。这一点非常重要,因为读入XML文档之后我们将立即开始使用它,如果此时文档还没有全部装载完毕,试图访问它就会引发错误。 >% Set objXML = Server.CreateObject("Microsoft.XMLDOM") objXML.async = False objXML.Load (Server.MapPath("mostRecentScriptingNews.xml")) %< 下面是我们装载的XML文档mostRecentScriptingNews.xml: >?xml version="1.0" encoding="gb2312" ?< >!DOCTYPE scriptingNews SYSTEM "http://www.scripting.com/dtd/scriptingNews.dtd"< >scriptingNews< >header< >copyright<版权所有>/copyright< >scriptingNewsVersion<1.0>/scriptingNewsVersion< >pubDate/pubDate< >lastBuildDate | /lastBuildDate< >/header< >item< >text/text< >link< >url/url< >linetext<汽车立体声系统>/linetext< >/link< >/item< ... >item< >text<据News.com,HP将以租用方式提供存储和计算服务。 >/text< >link< >url/url< >linetext<摘自News.com>/linetext< >/link< >/item< >/scriptingNews< DOM模型的parseError对象包含了最后出现的解析错误信息,这个错误对象对于ASP页面调试和错误控制是很有用的。文档装载完成后,在继续其他操作之前检查parseError对象看看是否存在错误是一种好习惯: >% If objXML.parseError.errorCode >< 0 Then &single; 处理错误 End If %< parseError对象提供了有关错误的丰富而宝贵的信息: parseError对象的属性 说明 errorCode 错误代码 filepos 出现错误的绝对文件位置 Line 出现错误行的行号 linepos 出现错误的字符在该行中的位置 reason 错误原因 srcText 出现错误的数据 URL 出错XML文档的URL 在本例中,XML文档引用了一个DTD(Document Type Definition,文档类型定义)文件,parseError在此具有更重要的意义。在这里,如果要求不出现错误,那么XML文档不仅必须格式良好(Well formed),而且它还必须对于指定DTD定义来说合法。装载XML文档之后总是检查一下parseError对象是一个好的编程习惯。 二、在服务器上处理XML(2) 现在DOM对象中已经有了一个格式良好的、合法的文档,我们来看看这个文档里面有些什么。DOM提供许多精确分析文档内容的方法。由于DOM将文档内容描述成一棵嵌套节点所组成的树(每个节点由一个元素及其所有子元素构成),因此处理XML数据实际上归结为处理一系列的节点对象。下面我们将用getElementsByTagName方法从文档获得元素(或节点)。 我们的第一个目标是找出新闻的发布日期。分析DTD文件,我们知道发布日期放在pubDate节点。访问该节点内容的一种比较简单的方法是,首先创建一个XML文档内所有节点的列表对象,然后用循环遍历这个列表直至找到pubDate节点。由于DTD规定了pubDate节点不能包含任何子节点,我们可以通过text属性直接得到节点的内容。 >% Set objXML = Server.CreateObject("Microsoft.XMLDOM") Set objLst = Server.CreateObject("Microsoft.XMLDOM") objXML.async = False objXML.Load (Server.MapPath("mostRecentScriptingNews.xml")) If objXML.parseError.errorCode >< 0 Then &single; 处理错误 End If Set objLst = objXML.getElementsByTagName("*") For i = 0 to (objLst.length ?1) If objLst.item(i).nodeName = "pubDate" Then StrDate = objLst.item(i).text Exit For End If Next %< 注意在上面的代码中我们以“*”作为getElementsByTagName的参数,此时getElementsByTagName将返回文档中所有元素(或节点)的一个列表。由于我们已经有了DTD,可以直接从DTD获知pubDate的正确位置,但象上例所做的那样通过循环遍历文档也是一种高效的方法,因为节点列表是一个集合。 现在我们得到了新闻的发布日期,下面我们来看看如何计算文档中的新闻数量。从文档的DTD定义我们知道新闻存放在item节点,文档中的每个item节点对应一则新闻。显然,我们可以使用类似上例的另一个循环,在循环内每次遇到item节点就把计数器加1。不过我们还有一种更好的提取该信息的方法,这要用到DOM提供的另外一个方法。 象上例一样,我们所要做的是创建一个包含全部item节点的列表对象,然后通过length属性得到节点列表对象中的节点数量,从而也就得到了文档中新闻的数量: >% Set objLst = objXML.getElementsByTagName("item") strNoOfHeadlines = objLst.Length %< 很多时候我们要在ASP页面中显示来自XML文档的一些信息。下面这个例子显示了如何通过遍历新闻节点列表,在ASP页面中显示新闻及其URL。 >% Set objXML = Server.CreateObject("Microsoft.XMLDOM") Set objLst = Server.CreateObject("Microsoft.XMLDOM") Set objHdl = Server.CreateObject("Microsoft.XMLDOM") objXML.async = False objXML.Load (Server.MapPath("mostRecentScriptingNews.xml")) If objXML.parseError.errorCode >< 0 Then &single; 处理错误 End If Set objLst = objXML.getElementsByTagName("item") noOfHeadlines = objLst.length %< >HTML<>BODY< >H1<新闻>/H1< >% For i = 0 To (noOfHeadlines ?1) Set objHdl = objLst.item(i) Response.Write(">a href=""" & _ objHdl.childNodes(1).childNodes(0).text & _ """<" & objHdl.childNodes(0).text & _ ">/a<>br<") Next %< >/BODY<>/HTML< 结束语:只要对XML文档的结构有一个基本了解,再利用DOM的强大功能,我们就可以方便地在ASP应用服务器端解析XML文档,从解析结果中选择合适的内容发送给客户端。这是一种浏览器无关的方法,适用于几乎所有的Web浏览器。 |
---|
相关文章推荐
- XML 在 ASP 环境下的应用(推荐)
- XML 在 ASP 环境下的应用(推荐)
- XML 在 ASP 环境下的应用(推荐)
- XML 在 ASP 环境下的应用(推荐)
- XML 在 ASP 环境下的应用(推荐)
- XML 在 ASP 环境下的应用(推荐)
- XML 在 ASP 环境下的应用
- XML 在 ASP 环境下的应用
- 谷歌Android手机应用开发环境的搭建 推荐
- Ajax之二: XMLHttpRequest之POST传递XML (应用环境: Windows + IE + .NET[C#])
- WebSphere Application Server 更新web.xml的问题以解决有些应用在tomcat环境下可以跑,更新到was上失效的问题
- ASP.NET AJAX客户端编程之旅(五)——以组件的思想开发Ajax应用:行为、绑定及xml-script
- asp+access环境下4款blog程序推荐
- 第9章 XML存储结构以及整合ASP的应用
- WebSphere Application Server 更新web.xml的问题以解决有些应用在tomcat环境下可以跑,更新到was上失效的问题
- Andriod应用对XML的解析 推荐
- 敏捷个人应用:开发环境搭建 推荐
- 演示:Linux工程环境应用实训(防火墙、NAT、静态路由)详细配步骤 推荐
- 《ASP.NET AJAX 应用剖析立即上手》推荐序!
- 《ASP.NET AJAX 应用剖析立即上手》推荐序!