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")
|