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攻略技巧 北京快乐8上下盘规则 上海时时乐APP 北京pk10单双大小计划 北京pk10从几点开始 北京pk10的公式怎么算
北京pk10冠军走势图 北京pk10冠军选号技巧 北京pk10冠军技巧 北京赛车pk10官网地址 上海时时乐走势图 北京pk10历史开奖记录
北京pk10冠亚军技巧 pk10冠军技巧 北京赛车pk10冠军公式 pk10冠军技巧5码公式 北京pk10冠军走势图 北京赛车pk10冠军公式
彩票直通车专家预测 北京pk10开奖号码 北京赛车pk10套利流水 北京pk10冠亚军和 闲1庄0.95刷反水怎么刷
北京早餐车加盟 黑龙江早餐加盟 汤包加盟 江苏早餐加盟 早餐肠粉加盟
广式早餐加盟 酒店加盟 新尚早餐加盟 安徽早餐加盟 早点夜宵加盟
早点连锁加盟店 早餐店 加盟 健康早餐加盟 东北早餐加盟 书店加盟
早餐豆腐脑加盟 早餐加盟费用 北京早点摊加盟 早点车加盟 早餐加盟费用
分分彩定位胆稳赚公式 北京赛车pk10稳赢公式 湖北十一选五一定牛 湖南快乐十分走势图 湖南快乐十分
时时彩平台出租55ur 广东36选7开奖号 麻将玩法 贵州快3开奖 江苏快三软件
贵州十一选五 极速快3网站 新疆十一选五x晚上 大赢家比分直播 极速时时彩官方开奖网
重庆幸运农场怎么注册 新加坡28开奖走势图 十吉林十一选五走势图 福彩东方6+1中奖规则 快乐扑克三开奖结果