Ajax核心:XMLHTTP组件相关技术资料

日期: 2008-03-04 作者:Jean-Jacques Dubray翻译:李非晓 来源:TechTarget中国

  一、数据库远程管理技术

  基于互联网的广域网现代应用中的一个重要环节是数据库远程监控。首先简单回顾一下互联网上的数据库远程管理技术的发展过程和方式.

  早期通过编写CGI-BIN程序模块进行数据库远程管理。但CGI-BIN的运行速度慢,维护很不方便,现在已经基本被弃用。

  这几年使用组件对象模型(Component Object Model, COM)的应用非常多,效果也很好。但如果使用的是第三方服务器(笔者的网站就是建立在第三方的虚拟主机上),服务器方往往因为保密或其它商业原因不允许用户注册自己的组件。

  近年来由微软公司推出的.NET平台和SUN公司的J2EE平台都是非常高档的数据库远程管理与服务平台。都能提供优质的多层(n-Tier)应用服务。 其中,.NET的简单对象访问协议(Simple Object Access Protocol, SOAP)使用超文本传输协议(Hypertext Transfer Protocol, HTTP)和扩展标记语言(Extensible Markup Language, XML)技术实现跨系统(例如Windows – Linux)的通讯服务方式已经广为开发商接受和使用。许多大型应用,例如企业资源计划(Enterprise resource planning, ERP)等都建立在这样的大型平台之上。 但对于中小型应用,比如一个网站的建设和维护,这种大型应用平台就显得有些尾大不掉,开销也过于庞大。

  曾经在互联网技术和Java技术方面一度落后的微软公司在XML应用开发则走在了前头。她的XML解析器(MSXML)中的XMLHTTP协议是一个非常方便实用的客户/服务通讯管道。综合运用XMLHTTP以及ActiveX数据对象(ActiveX Data Objects, ADO/ADOX)可以简单方便地实现数据库远程管理。

  二、数据库远程管理体系

  数据库远程管理的任务流程是:

  1、客户端向服务端发出数据库结构和数据的查询或修改指令。

  2、服务端接受并执行有关指令并向客户端返回结果。

  3、客户端接受并显示服务端返回的指令执行结果。

  实现数据库远程管理的二个主要关键环节是:

  1、客户端与服务端之间的指令上传和结果下传的数据通道,由XMLHTTP协议实现。

  2、服务端前沿与数据库之间的指令传送和结果返回,由起着中间层作用的ADO/ADOX接口完成。

  三、XMLHTTP的使用

  顾名思义,XMLHTTP是个传送XML格式数据的超文本传输协议。

  实际上,XMLHTTP的数据传输过程更为灵活一些:

  它上传的指令可以是XML格式数据,也可以是字符串,流,或者一个无符号整数数组。还可以是URL的参数。

  它下达的结果可以是XML格式数据,也可以是字符串,流,或者一个无符号整数数组。

  客户端调用XMLHTTP的过程很简单,只有5个步骤:

  1、创建XMLHTTP对象

  2、打开与服务端的连接,同时定义指令发送方式,服务网页(URL)和请求权限等。

  客户端通过Open命令打开与服务端的服务网页的连接。与普通HTTP指令传送一样,可以用"GET"方法或"POST"方法指向服务端的服务网页。

  3、发送指令。

  4、等待并接收服务端返回的处理结果。

  5、释放XMLHTTP对象

  XMLHTTP方法

  Open bstrMethod, bstrUrl, varAsync, bstrUser, bstrPassword

  bstrMethod:数据传送方式,即GET或POST。

  bstrUrl:服务网页的URL。

  varAsync:是否同步执行。缺省为True,即同步执行,但只能在DOM中实施同步执行。应用中一般将其置为False,即异步执行。

  bstrUser:用户名,可省略。

  bstrPassword:用户口令,可省略。

  Send varBody

  varBody:指令集。可以是XML格式数据,也可以是字符串,流,或者一个无符号整数数组。也可以省略,让指令通过Open方法的URL参数代入。

  setRequestHeader bstrHeader, bstrValue

  bstrHeader:HTTP 头(header)

  bstrValue:HTTP 头(header)的值

  如果Open方法定义为POST,可以定义表单方式上传xmlhttp.setRequestHeader "Content-Type", "application/x-www-form-urlencoded"

  XMLHTTP属性

  onreadystatechange:在同步执行方式下获得返回结果的事件句柄。只能在DOM中调用。

  responseBody:结果返回为无符号整数数组。

  responseStream:结果返回为IStream流。

  responseText :结果返回为字符串。

  responseXML:结果返回为XML格式数据。

  下面是本文附件源程序中的一个应用示例:

  Function GetResult(urlStr)
  Dim xmlHttp
  Dim retStr
  Set xmlHttp = CreateObject("Msxml2.XMLHTTP") ‘创建对象
  On Error Resume Next ‘出错处理
  xmlHttp.Open "POST", urlStr, False ‘用POST方式打开连接,异步执行。
  xmlHttp.setRequestHeader "Content-Type", "application/x-www-form-  urlencoded" ‘上传表单
  xmlHttp.Send ‘发送指令
  If Err.Number = 0 Then ‘如果连接正确
  retStr = xmlHttp.responseText ‘等待并获得服务端返回的结果字符串
  Else
  retStr = "Url not found" ‘否则返回出错信息
  End If
  Set xmlHttp = nothing ‘释放对象
  GetResult = retStr ‘返回结果
  End Function
  GetResult()函数带入一个服务网页的URL参数,把上传的指令安放在URL后面的参数上,如:
  urlStr = "server.asp?cmd=" & cmd & "&db=" & db & "table=" & table
  cmd:执行方式,例如查询,修改,删除等等。
  db:服务端数据库名
  table:服务端表名 

  然后提交指令,等待并接收返回的处理结果。结果以字符串方式返回。最后由函数调用者处理并显示结果。

我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。

我原创,你原创,我们的内容世界才会更加精彩!

【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】

微信公众号

TechTarget微信公众号二维码

TechTarget

官方微博

TechTarget中国官方微博二维码

TechTarget中国

相关推荐

  • 八个超实用的jQuery技巧攻略

    jQuery是JavaScript最好的库之一,主要用于制作动画、事件处理,支持Ajax及HTML脚本客户端。文中分享了8个超实用的jQuery代码技巧攻略,希望你会喜欢。

  • BEST:SOAP/XML和REST的替代方案

    虽然拥有大量的机架服务器,以及大量软件开发人员的组织,基于web和集成服务的SOAP和REST很适合他们,但也会出现问题。

  • Spring 烂!差!

    有些人可能对Spring的第一印象不太好,它真的很烂,很差吗,也许这只是你的一种偏见,它也有是自己的优点的。

  • 基于SOA架构的业务安全性研究

    SOA在提供价值链上企业之间信息共享和业务流程自动化的同时,也给业务信息安全带来了负面影响,且存在安全隐患,这些你知道吗?