>웹 프론트엔드 >JS 튜토리얼 >Ajax로 HTTP 스크립팅

Ajax로 HTTP 스크립팅

一个新手
一个新手원래의
2017-09-26 09:28:321483검색

AJax의 주요 기능은 스크립트를 사용하여 페이지를 다시 로드하지 않고도 HTTP와 웹 서버 간의 데이터 교환을 조작하는 것입니다.

XMLHttpRequest 사용

모든 최신 브라우저는 XMLHttpRequest 개체를 지원합니다(IE5 및 IE6은 ActiveXObject를 사용합니다).

XMLHttpRequest 개체 만들기

  • var xmlhttp =new XMLHttpRequest()var xmlhttp =new XMLHttpRequest()

  • var xmlhttp =new ActiveXObject("Microsoft.XMLHTTP");

var xmlhttp =new ActiveXObject("Microsoft.XMLHTTP");

예를 들어

function createXML(){
    if(typeof XMLHttpRequest != "undefined"){//标准
        return new XMLHttpRequest();
    }else if(typeof ActiveXObject != "undefined"){//兼容IE5,IE6
        if(typeof arguments.callee.activeXString != "string"){            
        var versions = ["MSXML2.XMLHttp.6.0","MSXML2.XMLHttp.3.0","MSXML2.XMLHttp"],i,len;            
        for (i=0,len=versions.length; i < len; i++) {                
        try{                    
        new ActiveXObject(versions[i]);                    
        arguments.callee.activeXString = versions[i];                    
        break;
                }catch(ex){                    //跳过
                }
            }
        }        
        return new ActiveXObject(arguments.callee.activeXString);
    }else{        
    throw new Error("no XRL object available.");
    }
}var xml = new createXML();

요청 지정
  • 객체가 생성된 후 http 요청을 시작하는 다음 단계는 XMLHttpRequest 객체의 open() 메서드를 호출하는 것입니다. 세 가지 매개변수를 받습니다:

  • 전송할 요청 유형, 대소문자 구분

  • 요청의 URL은 문서와 관련된 URL입니다. 절대 URL이 지정된 경우 프로토콜, 호스트 및 포트가 위치한 문서와 일치해야 합니다. 해당 콘텐츠: 교차 도메인 요청은 일반적으로 오류를 보고합니다.


  • 비동기적으로 보낼지 여부에 대한 부울 값
요청 헤더가 있는 경우 다음 단계는 이를 설정하는 것입니다.

    xml.setRequestHeader("Content-Type","text/plain");
  • 요청 헤더가 여러 번 호출되면 덮어쓰기가 발생하지 않습니다.

  • 요청에 비밀번호로 보호된 URL이 필요한 경우 사용자 이름과 비밀번호를 open()의 네 번째 및 다섯 번째 매개변수로 전달합니다

요청의 마지막 단계는 선택적 본문을 지정하여 서버로 보내는 것입니다. GET 요청에는 본문이 전혀 없지만 POST를 사용하여 요청을 보낼 때는 응답을 얻기 위해 setRequestHeader 메소드

xml.send(null);

와 협력해야 합니다.

완전한 HTTP 응답은 상태 코드, 컬렉션으로 구성됩니다. 응답 헤더 및 응답 본문. 이는 XMLHttpRequest 개체의 속성과 메서드를 통해 사용할 수 있습니다.
- status 및 statusText 속성은 HTTP 상태 코드(예: 200 ok)를 숫자와 텍스트 형식으로 반환합니다.
- 응답 헤더를 쿼리하려면 getResponseHeader 및 getAllResponseHeaders()를 사용하세요

- 응답 본문은 responseText 속성에서 텍스트 형식으로, responseXML 속성에서 문서 형식으로 얻을 수 있습니다

- XMLHttpRequest 객체는 일반적으로 비동기식으로 사용됩니다. send 메서드는 요청을 보낸 후 즉시 반환되며 이전에 나열된 응답 메서드와 속성은 응답이 반환될 때까지 유효하지 않습니다. 응답이 준비되었을 때 알림을 받으려면 XMLHttp 객체의 Readystatechange 이벤트를 수신해야 합니다 Ajax로 HTTP 스크립팅 ReadyState는 HTTP 요청의 상태를 지정하는 정수입니다

예를 들어

var xml = new createXML();xml.open("get","hello-world.html",false);xml.onreadystatechange = function(url,callback){    if(xml.readyState === 4){        if((xml.status >= 200 && xml.status < 300) || xml.status === 304){
            console.log(xml.responseText);
        }else{
            console.log("request is not ok" + xml.status);
        }
    }
}xml.send(null);

Ajax로 HTTP 스크립팅콘솔 출력

HTTP 헤더 정보Name의미 Accept브라우저가 처리할 수 있는 콘텐츠 유형Accept-Encoding표시할 수 있는 문자 집합Accept-Language처리할 수 있는 압축 인코딩Connection 브라우저 서버 연결 유형 Host페이지가 위치한 도메인쿠키쿠키는 페이지Referer요청하는 페이지 URL 사용자- 에이전트 서버 찾아보기 사용자 에이전트 문자열
🎜🎜🎜


可以自定义请求头部

xml.setRequestHeader("MyHeader","MyValue");

控制台输出

Ajax로 HTTP 스크립팅

相应,可以使用getAllResponseHeaders进行查询

Ajax로 HTTP 스크립팅

GET请求

可以将查询字符串参数添加到URL末尾。

function addURLParam(url,name,value){
    url += (url.indexOf(?) == -1 ? "?" : "&");
    url += encodeURIComponent(name) + "=" +encodeURIComponent(value);    
    return url;
}

POST请求

用来向服务器发送应该被保存的数据,将数据作为请求的主体提交,主体可以包含非常多的数据,并且数据格式不限

function submitData(){    
    var xml = createXML();    
    xml.onreadystatechange = function(){        
    if(xml.readyState === 4){            
    if((xml.status >= 200 && xml.status < 300) || xml.status === 304){
                console.log(xml.responseText);
            }else{
                console.log("request is not ok" + xml.status);
            }
        }
    }    
    xml.open("POST","postexample.php",true);    
    xml.setRequestHeader("Content-Type","application/x-www-form-urlencoded");//原因见表单编码的请求一节
    var form = document.getElementById("user-info");    
    xml.send(serialize(form));//serialize函数用来将页面中的表单数据格式化}

编码请求主体

表单编码的请求

  • 当用户提交表单时,表单中的数据编码到一个字符串中并随请求发送。默认情况下,HTML表单通过POST方法发送给服务器,编码后的表单数据则用作请求主体。对表单数据使用的编码方案:对每个单元素的键值对进行普通的URL编码,使用等号把编码后的名字和值连接起来,并使用&链接键值对,如:name1=value1&name2=value2;

  • 表单数据编码格式有一个正式的MIME类型:application/x-www-form-urlencoded,当使用POST方法提交表单数据时,必须设置Content-Type请求头为这个值。

举个栗子

function encodeFormData(data){
    if(!data) return "";//无数据就返回空串
    var pairs = [];//用来保存键值对
    for(var name in data){        if(!data.hasOwnProperty(name)) continue;//跳过继承属性
        if(typeof data[name] === "function") continue;//跳过方法
        var value = data[name].toString();
        name = encodeURIComponent(name.replace(/%20/g,"+"))//因为由于历史原因,表单提交的 x-www-form-urlencoded 格式要求空格编码为 + 。但 encodeURIComponent 是遵照后来的标准编码为 %20 的。
        value = encodeURIComponent(value.replace(/%20/g,"+"))
        pairs.push(name + "=" + value);
    }    return paris.join(&#39;&&#39;)//连接键值对}function getData(url,data,callback){
    var request = new XMLHttpRequest()
    request.open("GET",url+"?"+encodeFormData(data))
    request.onreadystatechange = function(){
        if(request.readyState === 4 && callback) callback(request)
    }
    request.send(null);
}function postData(url,data,callback){
    var request = new XMLHttpRequest();
    request.open("POST",url);
    request.onreadystatechange = function(){
        if(request.readyState === 4 && callback){
            callback(request);
        }
    }
    request.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
    request.send(encodeURIComponent(data));
}

JSON编码的请求

举个栗子

function postJson(url,data,callback){
    var request = new XMLHttpRequest();    
    request.open("POST",url);    
    request.onreadystatechange = function(){        
    if(request.readyState === 4 && callback){
            callback(request);
        }
    }    request.setRequestHeader("Content-Type","application/json");    
        request.send(JSON.stringify(data));
}

上传文件

举个栗子

input.addEventListener("change",function(){//添加事件监听
    var file = this.file[0];    
    var xhr = new XMLHttpRequest();
    xhr.open("POST",URL);
    xhr.send(file);
},false)

multipart/form-data 请求

当表单同时包含上传文件和其他元素的时候,浏览器必须使用“multipart/form-data”的特殊Content-Type来用POST方法提交表单。XHR2定义了新的FormData API,。

举个栗子

function postData(url,data,callback){
    var request = new XMLHttpRequest();
    request.open("POST",url);
    request.onreadystatechange = function(){
        if(request.readyState === 4 && callback){
            callback(request);
        }
    }    var form = document.getElementById("user-info");
    request.send(new FormData(form));
}

HTTP进度事件

六个基本事件
 loadstart:在接收到响应数据的第一个字节时触发
 progress:在接收响应期间持续不断地触
 error:在请求发生错误时触发
 abort:在因为调用abort()方法而终止连接时触发

load:在接收到完整的响应数据时触发
 loadend:在通信完成或者触发error、abort或load事件后触发

load事件

使用load事件代替onreadystatechange事件,响应完毕后就触发load事件,没有必要再去检查readystate属性。
只要浏览器接收到服务器的响应,无论状态如何,都会触发load事件,所以需要确定status属性值从而确定数据是否可用。

举个栗子

var xml = new createXML();xml.onload = function(event){    
    if((xml.status >= 200 && xml.status < 300) || xml.status === 304){        
    var request = document.getElementById("request");
        request.innerHTML = xml.responseText;
    }else{
        console.log("request is not ok" + xml.status);
    }
}xml.open("get","hello-world.html",false);xml.send(null);

progress事件

这个时间会在浏览器接受新数据期间周期性的触发。而progress事件处理程序会接收到一个event对象,其中target属性就是XHR对象,还有其他三种属性:lengthConputable表示进度信息是否可用的布尔值,loaded表示已经接收到的字节数,total表示根据Content-Length响应头部确定的预期字节数。

举个栗子

var xml = new createXML();xml.onload = function(event){    
    if((xml.status >= 200 && xml.status < 300) || xml.status === 304){        
    var request = document.getElementById("request");
        request.innerHTML = xml.responseText;

    }else{
        console.log("request is not ok" + xml.status);
    }
}xml.onprogress = function(event){    
    var p = document.getElementById("data");    
    if(event.lengthComputable){
        console.log(event.position);
        p.innerHTML = "Received " + event.loaded + " of " + event.total + " bytes";
    }
}/*需要注意的是,必须保证调用open之前定义onprogress事件处理程序*/xml.open("get","hello-world.html",true);xml.send(null);

终止请求和请求超时abort()

举个栗子

function timeGetText(url,timeout,callback){
    var request = new XMLHttpRequest();    
    var timedout = false; //判断是否超时
    var timer = setTimeout(function(){
        timedout = true;//超时
        request.abort();//触发终止事件
    },timeout);//如果超时,触发一个启动器
    request.open("GET",url);//发起请求
    request.onreadystatechange = function(){
        if(request.readyState !== 4) return;//忽略未完成程序
        if(timedout) return;//忽略超时程序
        clearTimeout(timer);//取消等待的超时
        if(request.status === 200){
            callback(request.responseText);//成功
        }
    }
    request.send(null);
}

图像ping

图像Ping最常用于跟踪用户点击页面或动态广告曝光次数。图像Ping有两个主要的缺点,一是只能发送GET请求,二是无法访问服务器的响应文本。

var img = new Image();
img.onload = img.onerror = function(){
    console.log("Done!");
};
img.src = "hello-world.html";

借助<script></script>发送HTTP请求:JSONP

  • 设置script元素也可以作为一种AJAX传输机制,只需要设置其src属性,浏览器就会发送一个HTTP请求以下载src属性指定的URL。

  • 使用这种方法进行传输的主要原因是它不受同源策略的影响,因此可以使用他们从其他服务器请求数据,还有一个原因是包含JSON数据的响应体会自动解码。

  • JSONP是JSON with padding的缩写。和JSON差不多,只不过是被包含在函数调用中的JSON。

  • JSONP由两部分组成,回调函数和数据。

举个栗子

var bd = document.body;function callbackFunction(result, methodName)
   {
       bd.innerText = result;
   }
   var script = document.createElement("script");
   script.src = "***/jsonp.php?jsoncallback=callbackFunction";
   bd.insertBefore(script,bd.firstChild);
  • 但是,不会强制指定客户端必须实现的回调函数,它们使用查询参数的值,允许客户端指定一个函数名,然后使用函数名去响应

举个栗子

function getJSONP(url,callback){
    var cbnum = "cb" + getJSONP.counter++;    
    var cbname = "getJSONP." + cbnum;    
    if(url.indexOf("?") === -1){
        url += "?jsonp=" + cbname;
    }else{
        url += "&jsonp=" + cbname;
    }    var script = document.createElement("script");
    getJSONP[cbname] = function(response){
        try{
            callback(response);
        }        finally{            delete getJSONP[cbname];
            script.parentNode.removeChild(script);
        }
    }
    script.src = url;
    document.body.appendChild(script);
}
getJSONP.counter = 0;

Conmet技术(服务器推送)

  • 有两种实现Comet的方式:长轮询和流。

  • 长轮询把传统轮询颠倒了一下,页面发送一个到服务器的请求,然后服务器一直保持连接打开,知道有数据可发送。发送完数据后,浏览器关闭连接,随即又发起一个到服务器的新请求。这个过程在页面打开期间一直不断持续。

  • 第二种流行的Comet方式是HTTP流。流在页面的整个生命周期中只使用一个HTTP连接。具体来说就是浏览器向服务器发送一个请求,然后服务器保持连接打开,然后周期性的向浏览器发送数据。

举个栗子

function createStreamingClient(url, progress/*接收到数据时调用的函数*/, finished/*关闭连接时调用的函数*/) {
    var xhr = new XMLHttpRequest(),
        received = 0;
    xhr.open("get", url, true);
    xhr.onreadystatechange = function() {
        var result;        if (xhr.readyState == 3) {
            result = xhr.responseText.substring(received);
            received += result.length;
            progress(result);
        } else if (xhr.readyState == 4) {
            finished(xhr.responseText);
        }
    };
    xhr.send(null);    return xhr;
}var client = createStreamingCilent("streaming.php", function(data) {
    alert("Received:" + data);
}, function(data) {
    alert("Done!");
});

服务器发送事件

SSE( Server - Sent Events, 服务器发送事件) 是围绕只读Comet交互推出的API或者模式。 SSE API用于创建到服务器的单向连接, 服务器通过这个连接可以发送任意数量的数据。 服务器响应的MIME类型必须是text / event - stream, 而且是浏览器中的Javascript API能解析的格式输出。 SSE支持短轮询, 长轮询和HTTP流, 而且能够在断开连接时自动确定何时重新连接。

SSE API

  • SSE是为javascript api与其他传递消息的javascript api很相似。 要预定新的事件流, 要创建新的EventSource对象, 并传入一个入口点:

var source = new EventSource("myevents.php");/*必须同源*/
  • EventSource的实例有一个readyState属性, 值为0表示正连接到服务器, 值为1表示打开了连接, 值为2表示关闭连接。还有三个事件:

open: 在建立连接时触发
 message: 在从服务器接收到新事件时触发
 error: 在无法建立连接时触发
  - 服务器返回的数据以字符串的格式保存在event.data中。 如果想强制立即断开并且不再重新连接, 可以调用close() 方法。

事件流

  • 响应格式为纯文本。

  • 对于多个连续数据,需要使用换行符分割。

  • 在设置了ID之后, EventSource对象会跟踪上一次触发的事件。 如果连接断开, 会向服务器发送一个包含名为Last - Event - ID的特殊HTTP头部请求, 以便服务器知道下次触发那个事件。 在多次连接的事件流中, 这种机制保证了浏览器能够以正确的顺序接收到连接的数据段。

Web Sockets

  • WebSocket是HTML5开始提供的一种在单个 TCP 连接上进行全双工通讯的协议。

  • 当创建web Sockets之后,会有一个http请求发送到浏览器以发起连接。在取得服务器响应后,建立的连接会从http协议交换为Web Socket协议

  • 由于使用了自定义的协议,未加密的URL是ws://,加密后的URLwss://

  • 好处是能够在客户端和服务器之间发送非常少的数据,而不必担心http那样字节级的开销。

var Socket = new WebSocket(url, [protocol]/*可接受的子协议*/ );//创建对象

Ajax로 HTTP 스크립팅


事件 事件处理程序 描述
open Socket.onopen 连接建立时触发
message Socket.onmessage 客户端接收服务端数据时触发
error Socket.onerror 通信发生错误时触发
close Socket.onclose 连接关闭时触发

参考文档——websocket

AJax的主要特点是使用脚本操纵HTTP和web服务器之间的数据交换,不会导致页面重载。

위 내용은 Ajax로 HTTP 스크립팅의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.