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(#替换为@)。期待你的好消息!
上海时时乐即时开奖结果查询 北京快乐8上下盘 北京pk10冠军稳赚技巧 北京快乐8在线计划 北京pk10多久开一期 北京pk10冠军专家技巧规律
北京pk10冠亚军技巧 北京pk10冠军技巧 北京pk10冠军走势图 上海时时乐组选走势图
pk10冠军技巧 pk10冠军技巧5码公式 北京pk10猜冠军技巧 pk10冠军技巧5码公式 pk10冠军技巧5码公式
北京pk10冠亚和值口诀 北京pk10计算公式 上海今时时乐开奖结果 上海今时时乐开奖结果 北京pk10是正规的吗
早点快餐店加盟 加盟早点 湖南特色早点加盟 哪家早点加盟好 早餐面馆加盟
上海早餐加盟 品牌早餐加盟 品牌早点加盟 陕西早点加盟 早点来早餐加盟
包子早餐加盟 早餐店加盟 口口香早点加盟 早点连锁加盟店 绿色早餐加盟
灯饰加盟 四川特色早点加盟 书店加盟 早点来加盟 早餐包子加盟
北京赛车pk10开奖直播官网 双色球开奖走势图 天津时时彩 浙江11选5 秒速飞艇是正规?
本港台开奖现场报码 浙江快乐12开奖走势图 内蒙古快3ds99.vip k3k捕鱼棋牌游戏 重庆时时彩走势图网易
南粤风采36选7走势图 香港开奖现场直播 湖南体彩网幸运赛车开奖结果 广西11选5几天开 北京pk10开奖记录
北京快乐8开奖视频 内蒙古11选5走势图今天 北京赛车平刷王 加拿大28预测55 河南快赢481直播