Sub abort()

中断当前对象的HTTP请求.

 

 Function getAllResponseHeaders() As String

获取HTTP响应结果中的全部Header信息,以字符串格式表示

 

 Function getResponseHeader(bstrHeader As String) As String

 

获取HTTP响应结果Header中指定名称的值,用字符串表示,如果不存在则返回空串

 

Sub open(bstrMethod As String, bstrUrl As String, [varAsync], [bstrUser], [bstrPassword])

初始化HTTP连接请求对象,设置请求方法,地址,认证信息.

bstrMethod可用值有GET,POST,HEAD,定义向HTTP提交请求的方式;必填

bstrUrl为要访问的HTTP资源地址;必填

varAsync 可选项,设置是异步还是同步等待返回结果,true-异步方式,false-同步方式,缺省是异步方式;

如果HTTP请求要求用户名和口令,则在bstrUser,bstrPassword中设置.

 

 

Sub send ([varBody])

向服务器发送一个HTTP请求,并获取返回结果.

varBody为要发送到服务器的数据,通常在POST方式下使用.

 

Sub setRequestHeader(bstrHeader As String, bstrValue As String)

在请求header中设置bstrHeader/bstrValue值对并发送到服务器端.

例:

xmlReq.setRequestHeader("Content-Type",

"application/x-www-form-urlencoded; charset=UTF-8");

 

 

 XMLHTTP属性

 

onreadystatechange

 

 设置请求对象状态readystate改变时要调用的函数对象;

 

readyState

 

请求对象的状态值,含义如下:

0 - 请求对象被创建,但未初始化,即open方法未调用

1 - 装载中,open方法已调用,send方法未调用

2 - 已装载,send方法已调用,但还未获得Header信息

3 - 交互中,已获取了部分信息,这时调用responseText将得到不完整信息,会返回错误

4 - 所有数据已接收完成,可用responseText或responseBody得到完整数据

 

 responseBody

 

表示从HTTP响应得到的返回原始信息,内容的编码方式决定于请求的服务器端(UTF-8, UCS-2, UCS-4, Shift_JIS等)

 

responseText

 

 HTTP请求返回数据体的字符串表示,缺省情况下用utf-8编码后返回,如果返回内容中有中文,服务器端的数据必须用utf-8编码,否则就会出现乱码。

 

responseStream

 

HTTP请求返回数据的流对象,该对象实现IStream接口.

 

responseXML

 

返回XML格式的数据对象. 服务器端返回数据为XML格式数据时可用.服务器端用动态语言生成xml时,必须设置content-type为text/xml,否则客户端得到的responseXML为空

 

status

 HTTP返回代码.

200 - 成功

404 - 错误请求

500 - 服务器内部错误,等等. 详见HTTP协议.

 

statusText

HTTP返回状态文本描述.

 

上面说明了XMLHTTP的方法和属性,下面列一些使用实例.

 

 

 例1  连接到google,显示获得的信息

 

 

<script language="javascript">

 

 

function getGoogle(){

    var xmlReq ;

    try{

        xmlReq = new ActiveXObject("Microsoft.XMLHTTP");

 

        var web = "http://www.google.com";

 

        //异步方式

        xmlReq.open("GET",web,true);

        xmlReq.onreadystatechange = function(){

              if (xmlReq.readystate == 4){

                      document.write(xmlReq.responseText);

              }

 

        }

 

        xmlReq.send();

 

    catch(e){

       

         alert(e);

    }

    

}

 

</script>

 

 

 例2 用POST方法发送数据到web服务器

 

<script language="javascript" >

    var xmlReq ;

    function sendData(){

        

          try{

 

                    xmlReq = new ActiveXObject("MSXML2.XMLHTTP");

                    var data = "name=james&id=1234";

                    var web = "http://www.myweb.com/login.jsp"    //实际运行要换为存在的一个地址

                    xmlReq.open("POST",web,true);

                    xmlReq.onreadystatechange = resHandler;         //设置返回值处理函数

                    xmlReq.setRequestHeader("Content-Type","

           xmlReq.setRequestHeader("Content-Type",

"application/x-www-form-urlencoded; charset=UTF-8");

                    xmlReq.send(data);

 

          } catch(e) {

               alert(e);

          }

 

    }

 

 

    function ResHandler(){

           if (xmlReq.readystate == 4){

                

                  alert(xmlReq.responseText);

 

           }

    }

 

 

</script>

 

 

在Mozilla浏览器中要用xmlReq = new XMLHttpRequest()来创建HTTP请求对象. 其他使用方法与MSXML相同。基于安全问题,如果open中访问的是另外的域,浏览器通常会禁止这种操作,要跨域访问需修改安全配置。