XMLHTTP使用具体解释

XMLHTTP使用具体解释

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

XMLHTTP对象是Microsoft的MSXML开发包中带的一个用HTTP,XML协议訪问web资源的对象. 从MSXML3.0開始出现. 它在AJAX技术中主要用来从其它网络资源获取信息,然后由javascript来更新页面中的部分内容.
採用这样的方法将页面可更新内容细化,不须要更新非常少的内容而刷新整个页面.
 
XMLHTTP对象的用法例如以下:
1- 创建XMLHTTP对象,不同的浏览器创建方式不同,本文以IE为例说明.
2- 用XMLHTTP对象向外部资源发送请求信息, 同步或异步获得返回结果
3- 处理返回结果,在页面上显示,这时要用到javascript相关技术
 
XMLHTTP对象的方法例如以下: (函数原型採用VB语法)
 
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请求要求username和口令,则在bstrUser,bstrPassword中设置.
 
 
Sub send ([varBody])
向server发送一个HTTP请求,并获取返回结果.
varBody为要发送到server的数据,通常在POST方式下使用.
 
Sub setRequestHeader(bstrHeader As String, bstrValue As String)
在请求header中设置bstrHeader/bstrValue值对并发送到server端.
例:

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响应得到的返回原始信息,内容的编码方式决定于请求的server端(UTF-8, UCS-2, UCS-4, Shift_JIS等)

 

responseText

 

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

 

responseStream

 

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

 

responseXML

 

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

 

status

 HTTP返回代码.
200 – 成功
404 – 错误请求
500 – server内部错误,等等. 详见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方法发送数据到webserver
 
<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中訪问的是另外的域,浏览器一般会禁止这样的操作,要跨域訪问需改动安全配置。
 
 
參考文档:
 
1 –
http://msdn.microsoft.com  中MSXML SDK
 
 
 
 
 
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/118398.html原文链接:https://javaforall.net

(0)
上一篇 2021年12月6日 下午7:00
下一篇 2021年12月6日 下午8:00


相关推荐

  • 大模型视觉测评榜单出炉:Gemini遥遥领先 豆包冲进前三

    大模型视觉测评榜单出炉:Gemini遥遥领先 豆包冲进前三

    2026年3月12日
    2
  • javascript 暂时性死区[通俗易懂]

    javascript 暂时性死区[通俗易懂]暂时性死区:ES6之前JS的一个BUG(美其名曰暂时性死区)。在使用typeof等运算符操作一个未声明的变量时,不会报错,该变量的值以undefined作处理ES6:ES6的变量声明方法(let,const,class…)解决了暂时性死区问题,会进行显式报错。ES6之前的暂时性死区console.log(typeofa); //undefined(noerror)ES6之后的变量声明console.log(typeofa); //UncaughtRefe..

    2022年6月15日
    66
  • 蓝桥 史丰收速算

    蓝桥 史丰收速算史丰收速算法的革命性贡献是 从高位算起 预测进位 不需要九九表 彻底颠覆了传统手算 nbsp nbsp 速算的核心基础是 1 位数乘以多位数的乘法 nbsp nbsp 其中 乘以 7 是最复杂的 就以它为例 nbsp nbsp 因为 1 7 是个循环小数 0 如果多位数超过 就要进 1 nbsp nbsp 同理 2 7 3 7 6 7 也都是类似的循环小数

    2026年3月19日
    2
  • Error:java: Annotation processing is not supported for module cycles.异常解决

    Error:java: Annotation processing is not supported for module cycles.异常解决nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp 有一段时间没碰 Springboot 想起用到它的时候还是在去年 nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp 由于要开始准备毕设了 所以最近开始部署 Springboot 的项目 结果在启动的时候 报了以下异常 Error java Annotatio

    2026年3月17日
    2
  • PLD,CPLD,FPGA区别[通俗易懂]

    PLD,CPLD,FPGA区别[通俗易懂]入门以后可以学习Xilinx的ISE,Altera的QuartusII学习CPLD初学者,建议选用LATTICE,这家公司在此方面有优势主流还是Altera和Xilinx,毕竟是最大的两家PLD公司(Cyclone   Spartan) PLD,CPLD,FPGA有何不同?不同厂家的叫法不尽相同,  PLD(ProgrammableLogicDevice)是可编程逻辑器件的总称

    2022年5月4日
    97
  • threadpoolmanager_threadlocal是线程安全的吗

    threadpoolmanager_threadlocal是线程安全的吗在WEB开发中,为了减少页面等待时间提高用户体验,我们往往会把一些浪费时间的操作放到新线程中在后台运行。简单的实现代码就是://代码一newThread(()=&gt;{//dosomething}).Start();但是对于一个请求量大的网址这样做是很不现实的——每一个操作都要开启一个新线程,最终会因CPU不堪重负而使网站挂掉。更好的做法是使用线程队列。对于线程队列 ThreadPoo…

    2026年3月8日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号