XMLHTTP组件应用
北京pk10冠军技 发布时间:03-31 来源:鹏鹏编程网 浏览:41次
一、数据库远程管理技术 

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

早期通过编写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:服务端表名 

然后提交指令,等待并接收返回的处理结果。结果以字符串方式返回。最后由函数调用者处理并显示结果。
如果你有好的win10资讯或者win10教程,以及win10相关的问题想要获得win10系统下载的关注与报道。
欢迎加入发送邮件到657025171#qq.com(#替换为@)。期待你的好消息!
上海时时乐多少算小 北京pk10彩票是国家办的吗 北京pk10单双大小玩法 上海时时乐开奖号 北京快乐8有假吗 北京快乐8违法
北京pk10猜冠军技巧 北京赛车pk10冠军公式 北京pk10大特规律 上海时时乐万能码 北京pk10计划
pk10冠军技巧5码公式 北京pk10冠军走势图 pk10冠军技巧 北京pk10猜冠军技巧 北京pk10猜冠军技巧 pk10冠军技巧
北京pk10怎样看走势图 pk10北京赛车8码计划 北京pk10高手计划群 北京快乐8压大小的方法 什么数字代表节日快乐 北京pk10龙虎买法技巧
早点豆浆加盟 新尚早餐加盟 安徽早餐加盟 河南早点加盟 自助早餐加盟
必胜客加盟费及加盟条件 特色早餐店加盟 早点小吃加盟连锁 哪家早点加盟好 早点铺加盟
爱心早餐加盟 早点快餐加盟店 便民早点加盟 我想加盟早点 早点加盟哪家好
早点加盟小吃 双合成早餐加盟 娘家早点车怎么加盟 北京早点小吃加盟店 连锁店加盟
四川时时彩app 快乐十分官方网站 香港六合彩特码 2018六开彩开奖结果 香港六合彩总公司
开奖广东36选7 精准平特一肖王中王 内幕爆料一码中特 31选7走势图 陕西11选5走势图
内蒙快三直播那里看 上海pk10长龙连开20期 11选5任六必中组合 福建22选5公式 刮刮乐吧
河北11选五开奖结果 澳洲幸运10技巧 天津十一选五计划 新疆时时彩历史记录 香港商会9769最早发布