找到一篇关于xmlhttp的文章
发表于:2007-06-30来源:作者:点击数:
标签:
XMLHTTP: 网站超级粘合剂 简介 许多ASP 开发 者都希望在自己的网站中能够使用到微软提供的支持XML 的新功能。其中,有些人发现可以使用XML来装饰网站,但是,如果仅仅 是只使用XMLDOM的话,你就会失去其他一些更重要的东西。毕竟,XML是用来 作为一种网上数据
XMLHTTP: 网站超级粘合剂
简介
许多ASP
开发者都希望在自己的网站中能够使用到微软提供的支持XML
的新功能。其中,有些人发现可以使用XML来装饰网站,但是,如果仅仅
是只使用XMLDOM的话,你就会失去其他一些更重要的东西。毕竟,XML是用来
作为一种网上数据表现和数据交换的形象出现的。尽管使用XML可以非常满意
地描绘你的数据,但是开发者却不得不使用CGI来进行浏览器和
服务器之间的
数据交换,除非你在浏览器端和客户端都使用XML文档。
当然CGI从传达信息的角度来说是能够完全胜任的,但是如果要是和XML来
一起使用的话就让XML失去了很多自己的用处。幸运的是,微软提供了一种更加
有效的方法来传输XML,虽然该方法在很大程度上并不被人所重视。
在微软提供的MSXML解释器包中有一系列的对象,也许没有人会重视其中的
XMLHTTPConnection对象。简而言之,它允许你打开一个到服务器上的HTTP连接,
发送一些数据和取回一些数据。并且所有的这一切都是在很少的几段脚本中就能够实现。
使用XMLHTTP对象通常是进行XML数据交换,但其他格式的数据也是允许的。
在商业程序中的运用
这种交换类型的标准模式是客户端发送一个XML格式的文本字符串到服务端,
然后服务端将这个字符串装载入一个XMLDOM对象中并且解释它,然后返回一段
HTML给客户端,或则是另外一段XML代码给客户端让客户端的浏览器自己解释。
在这种方式下,对于信息的传递来说是非常有效的形式,尤其是当你使用
DHTML允许你根据返回信息动态显示时。
举例如下(只能够运行在客户端和服务端都安装有IE5的情况下)
<%
if (Request.ServerVariables("REQUEST_METHOD") == "POST" )
{
var req= Server.CreateObject("Microsoft.XMLDOM");
req.async=false;
req.load(Request);
if (req.documentElement.nodeName=="timesheet")
{
//对数据随便进行一些处理。。。
.....
Response.write("<h1>Timesheet Updated!</h1><b>"+req.documentElement.text+"</b>");
}
}
else
{ %>
<div id="divDisplay">The response will be put in here</div>
<input type="button" onclick="sendData();" value="Send it!">
<script>
function sendData(){
var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
xmlhttp.Open("POST", "http://www.yoursite.com/thispage.asp", false);
xmlhttp.Send("<timesheet>An impossibly useless timesheet fragment</timesheet>");
divDisplay.innerHTML=xmlhttp.responseText;
}
</script>
<% } %>
在上面的代码中,其中客户端的脚本将建立一个适当的COM对象,打开一个在网站
www.yoursite.com的连接(使用了HTTP的POST方法,同步方式),使用Send方法发送
一个XML片段,然后根据服务器上的响应填充divDisplay区域(这里使用了DHTML)。
具体的执行过程是,在服务器上,Request对象被转载入一个XML文档然后被解释器解释。
服务器响应XMLHTTP连接的方式和响应其他任何方式的HTTP连接是一样的,也是使用了
Response对象。注意的是XMLHTTP本身并不检查request或则response的有效性,也就是说
Request或则Response中的数据可是并不需要一定是XML文档。
“聪明,”你也许会说。“但是为什么我们不使用CGI来代替它呢?”呵呵,我们要注意
这样一件事,就是如果使用这种方式进行客户端--服务端的交互时整个页面并没有被刷新。
我们都知道,如果要是通过CGI来做任何事情都必将导致浏览器接收一个完整的新页面,而
这尤其影响网站上的访问者,因为他们不得不把所有的时间都用来等候整个页面
下载完毕。
同样,CGI对于网站服务器来说也是一个负担,因为它不得不把宝贵的处理器循环周期和带宽
消耗在新页面的所有部分。如果这样的操作只是一次或则两次倒无所谓,但是如果是对任何
一个电子商务网站或则一个基于Web的电子邮件系统,这将意味着大量的同样的基本页面信息
被重复一次又一次的装载。
同样,如果是通过CGI在网站运用程序中使用XML,服务端一般都将不得不根据数据来建立
XML的文档,然后才能够对这些文档进行自己需要的处理。在这种方式下,服务器将花费
大量的精力在处理如何建构这些XML文档上,尤其是当需要传送的数据量很大时。
所以如果是让客户端的浏览器来建立这个XML文档,并且在建立完毕后通过XMLHTTP将最后的
产品传递给服务器,这将大大减轻服务端的代码量和负担。
这种类型的问题的一个例子是给服务器上的XML文档增加数据。如果是使用CGI的话,那么
就需要频繁的查询一个CGI的form,然后才能够构建一个加入XML文档的XML节点。而如果是使用
XMLHTTP需要做的仅仅是把这个XML节点传递给服务端就可以了。
上面说讨论的是XMLHTTP基本部分,有关它的详细例子你可以在Microsoft Developers
Network中找到例子 。虽然使用这种通讯方式可以大有作为,我在我自己的运用中仅仅只是
使用到了很少的一部分,也许任何一个聪明的开发者都能够发现更多的运用事例。
使用XMLHTTP而不是CGI(即使是我们心爱的ASP)能够让我编写更多野心勃勃的网站运用
程序,因为现在我们所关心的简单到只是我们需要发送的数据而已。从而使用很少的代码
就能够实现非常复杂的功能,而CGI对于用户每一个可能的操作都需要我们来完完整整地
生成一个新的页面。
但是由于目前并不是所有的浏览器都支持MSXML,许多使用ASP编写的为了非企业内部
目的的运用程序需要支持CGI的交互。但是欣慰的是,编写一个同时支持CGI和XMLHTTP数据
的页面并不是很困难,并且将CGI的数据载入XML文档中花费的工作量也不是很大。
最简单的方式来判断数据是CGI的数据还是XML的数据就是判断数据的
MIME类型.
XMLHTTP的MIME是一个空字符串,除非你特定了其他的MIME类型 (可以到这个连接
查看不同的MIME类型http://msdn.microsoft.com/xml/reference/scriptref/XMLHttpRequest_object.asp).
而许多CGI的MIME类型是"application/x-www-form-urlencoded"
下面就是一个来判断的代码片段:
<%
if (Request.ServerVariables("REQUEST_METHOD") == "POST" )
{
if (Request.ServerVariables("CONTENT_TYPE")=="application/x-www-form-urlencoded")
{//如果是常规数据,让CGI来处理
Response.write(Request.form("stuff"));
}
else
{//如果是XMLHTTP连接,将Request对象转载入XML解释器
var req= Server.CreateObject("Microsoft.XMLDOM");
req.resolveExternals=false;
req.validateOnParse=false;
req.async=false;
req.load(Request);
Response.write(req.documentElement.selectSingleNode("stuff").text);
}
}
else{ %>
这是一种简单明了的在同一个ASP页面中即可以处理CGI也可以处理XMLHTTP数据的方法。
并且它也提供了一种能够兼容在客户端安装了IE5.0以及使用其他其他浏览器浏览网站的模式。
或则也可以采取另外一种方法,就是我对所有的网站运用程序还是采用以前的CGI接口,
但是在其他类型的客户端运用程序使用XMLHTTP方法,例如Microsoft Office运用程序。
XMLHTTP的功能并不仅仅局限在浏览器上,我在Microsoft Office的
VBA开发程序中使用XMLHTTP
取得了巨大的成功。现在我假设我被要求使用XML技术在更新我公司服务器上的Excel电子表
格中的数据。Excel能够将HTML表格直接转载到自己的表格中,但是它不能够处理格式复杂的
页面,例如本页。数据除非使用了非常巧妙的技巧根本没法插入电子表格。
我的解决方法是编写了一个ASP页面来操纵通过XMLHTTP从Excel中传递过来的数据。
通过一个VBA的宏给服务器发送一个请求,然后将响应载入XML文档,通过解释器解释后再
插入Excel的电子表格中。这将是一个无痕的
解决方案,简单的一个按钮也许会让你的老板、
同事或任何其他人的关系大有改观。
下面是我实现上述方法的一个代码片段。它使用XMLHTTP将服务器中的信息载入,然后将
其插入电子表格中。
Public Sub UpdateSheet()
Dim xmlhttp
Set xmlhttp = CreateObject("Microsoft.XMLHTTP")
Call xmlhttp.Open("POST", "http://www.yourserver.com/yourpage.asp", False)
Call xmlhttp.send("<reqtimesheet user=@#jimbob@#/>")
Dim xmldoc
Set xmldoc = CreateObject("Microsoft.XMLDOM")
xmldoc.async = False
xmldoc.loadxml(xmlhttp.responsexml)
Worksheets("TimeSheet").Range("A1").Value = xmldoc.documentelement.getAttribute("firstname")
Worksheets("TimeSheet").Range("B1").Value = xmldoc.documentelement.getAttribute("lastname")
Worksheets("TimeSheet").Range("C37").Value = xmldoc.documentelement.selectSingleNode("totalhours").Text
End Sub
这个VBA的宏相当的简单。给服务器发送一个请求,然后将服务器上的响应插入
XML文档,然后更新Excel中cell中的内容。当然,我们可以使用这个技术做其他更多的运用。
例如从一个Office运用程序中上载数据到服务器上的XML文档中(XML应该是你首选的格式,
而不是Office 2000中提供的愚蠢的OfficeXML实现).或则把XML/ASP作为一个你
数据库的shell
这样,你的运用程序对于数据库就有了一个简洁、统一的接口,而对数据库结构的
改动就不必要改动你所有的客户端代码了。
我发现XMLHTTP对象在我的编程中非常的有用。我一般使用Visual Basic, Delphi, 和 Visual J++编写程序,在这个过程中,我经常发现这些语言各自对在线程序处理的方法非常地不同,
他们各自有自己的对
网络程序的处理机制,但是如果你要是在处理网络程序时都使用统一
的XMLHTTP连接方式,那么连接服务器的代码将非常小,甚至更优化,这是一种对所有的
语言都统一的接口。
原文转自:http://www.ltesting.net