MSXML中提供了Microsoft.XMLHTTP对象,能够完成从数据包到Request对象的转换以及发送任务。 创建XMLHTTP对象的语句如下: Set objXML = createObject(Msxml2.XMLHTTP) 或 Set objXML = createObject("Microsoft.XMLHTTP") ' Or, for version 3.0 of XMLHTTP, use: ' Set xml = Server.createObject(MSXML2.ServerXMLHTTP) 对象创建后调用Open方法对Request对象进行初始化,语法格式为: poster.open http-method, url, async, userID, password Open方法中包含了5个参数,前三个是必要的,后两个是可选的(在服务器需要进行身份验证时提供)。参数的含义如下所示: http-method: HTTP的通信方式,比如GET或是 POST url: 接收XML数据的服务器的URL地址。通常在URL中要指明 ASP或CGI程序 async: 一个布尔标识,说明请求是否为异步的。如果是异步通信方式(true),客户机就不等待服务器的响应;如果是同步方式(false),客户机就要等到服务器返回消息后才去执行其他操作 userID 用户ID,用于服务器身份验证 password 用户密码,用于服务器身份验证 XMLHTTP对象的Send方法 用Open方法对Request对象进行初始化后,调用Send方法发送XML数据 poster.send XML-data Send方法的参数类型是Variant,可以是字符串、DOM树或任意数据流。发送数据的方式分为同步和异步两种。在异步方式下,数据包一旦发送完毕,就结束Send进程,客户机执行其他的操作;而在同步方式下,客户机要等到服务器返回确认消息后才结束Send进程。 XMLHTTP对象中的readyState属性能够反映出服务器在处理请求时的进展状况。客户机的程序可以根据这个状态信息设置相应的事件处理方法。属性值及其含义如下表所示: 值 说明 0 Response对象已经创建,但XML文档上载过程尚未结束 1 XML文档已经装载完毕 2 XML文档已经装载完毕,正在处理中 3 部分XML文档已经解析 4 文档已经解析完毕,客户端可以接受返回消息
客户机处理响应信息 客户机接收到返回消息后,进行简单的处理,基本上就完成了C/S之间的一个交互周期。客户机接收响应是通过XMLHTTP对象的属性实现的: ● responseTxt:将返回消息作为文本字符串; ● responseXML:将返回消息视为XML文档,在服务器响应消息中含有XML数据时使用; ● responseStream:将返回消息视为Stream对象。 AspHTTP组件的属性
Accept 指示什么样的MIME类型可以被请求程序接受 例如: HttpObj.Accept = "*/*"
Authorization 授权头可以让你获得 需要验证身份的地方的url 用户名和口令之间用冒号点开 例如: HttpObj.Authorization = "jimb:superbmr"
BinaryData 返回来自getURl请求获得的两进制格式的数据,你可以用这个属性取得两进制数据 如来自另一个web服务器的图片例如: <% Response.ContentType = "image/gif" Set HTTPObj = Server.createObject("AspHTTP.Conn") HTTPObj.Url = "/blog/upload/200562215730899.gif" HTTPObj.GetURL Response.BinaryWrite HTTPObj.BinaryData %>
ContentType 这个属性允许你在POST***作时自定义content-type头 例如: ContentType = "application/x-www-form-urlencoded"
Error 报告请求中发生的任何错误
FollowRedirects FollowRedirects告诉组件跟随HTTP Server的重定向 例如: HttpObj.FollowRedirects = true
Headers Headers属性包含了在请求被调用GetURL处理完成之后,来自http请求的回应头 例如: Response.Write HttpObj.Headers
Port Port属性指示连接http服务器的端口号 例如: HttpObj.Port = 80
PostData PostData属性应该被设置为你希望post请求POST到web服务器的数据的值 例如: HttpObj.PostData = "suid=jimb&act=upd"
Protocol 指示请求应该使用的http协议版本号,缺省值是HTTP/1.0 例如: HttpObj.Protocol = "HTTP/1.1"
Proxy proxy属性包含proxy server代理服务器的地址/端口,冒号点开 例如: HttpObj.Proxy = "address.net:2001"
ProxyPassword 设置需要验证的http代理服务器的http代理密码,现在只支持basic authentication(基本验证)
RequestMethod RequestMethod属性指示发给服务器http请求的类型,合法的值是"GET", "POST" 和 "HEAD". 例如: HttpObj.RequestMethod = "POST"
RegisteredUser RegisteredUser属性指示组件授权用户的名字 例如: Response.Write "This component is licensed to " & HttpObj.RegisteredUser
Response Response属性包含在收到web服务器过来的请求之后的http response回应
SaveFileTo SaveFileTo允许你得到任何类型的文件,自动存到本地盘上。图形/文本/HTML文件均可以。 例如: HttpObj.SaveFileTo = "c:\images\3rdqrtr.jpg"
TimeOut timeout属性决定组件等待http server响应的时间 例如: HttpObj.TimeOut = 45
URL URL属性设定你希望request请求所***作的url,以http://开头 例如: HttpObj.URL = "http://www.myfinancial.com/scripts/update3.asp"
UserAgent UserAgent让组件通过发送一个request的UserAgent头伪装浏览器 例如: HttpObj.UserAgent = "Mozilla Compatible (MS IE 3.01 WinNT)"
Version 指示AspHTTP组件的版本 例如: Response.Write "The component version is " & HttpObj.Version
AspHTTP组件的方法
方法 参数 返回值 描述 GetURL 无 String 返回http请求的响应,这是一个字符串,组件不支持2进制返回值,如Gif/Jpg图像 AddExtraHeader String 无 在请求内增加一个自定义的http头,自定义头可以包括模拟的浏览器头,例如IE的分辨率信息头 ClearExtraHeaders 无 无 清除所有AddExtraHeader设置的http头 GetHeader String String 在GetUrl调用之后,获得自定头的值,如果有多个头,返回第一个。要检索所有的头,请看GetHeaders Example: strCookie = HttpObj.GetHeader("Set-Cookie") You could then on subsequent calls return the same cookie as follows: if strCookie <> "" then HttpObj.AddExtraHeader "Cookie: " & strCookie end if GetHREFs 无 Variant 字符串数组,在调用GetUrl之后,你可以调用GetHREFs处理html里面的<a href=""> Tags. GetHREFs返回一个你可以进一步处理或显示的字符串的可变数组 请见HREFList.asp(下载包内有)使用这个方法的示例代码,GetHREFs是在aspHTTP版本2.4增加的。 URLDecode strValue String 解码一个URL编码的字符串 URLEncode strValue String 将一个字符串编码成一个合法的url值 Example: HttpObj.URL = HttpObj.URLEncode("http://www.test_xyz.com?avalue=this is a value with spaces")
至少要成为本站的注册会员才能下载! 注册点我!
|