Asynchronous JavaScript + XML,支持js与服务器通讯。在不unload页面的前提下从服务器获取新数据,以实现更好的用户体验(与传统的单击-等待交互不一样的体验)。javascript
IE5最早提供了支持,在MSXML库中新增了XHR对象(XMLHttpRequest),能够经过new ActiveXObject(str)的方式建立XHR对象,虽然不是很方便,但至少是原生支持html
XMLHttpRequest,[IE6-]对XHR对象的实现与其它浏览器不一样,但能够经过对象检测来建立跨浏览器的XHR对象,具体代码以下:java
/*获取HttpRequest对象,能够兼容各个浏览器 包括IE5.5+*/ function getHttpObject(){ if(typeof XMLHttpRequest == "undefined"){//若是该对象未定义,则自定义该对象 XMLHttpRequest = function(){ try{ return new ActiveXObject("Msxml2.XMLHTTP.6.0"); }catch(e){} try{ return new ActiveXObject("Msxml2.XMLHTTP.3.0"); }catch(e){} try{ return new ActiveXObject("Msxml2.XMLHTTP"); }catch(e){} try{//老版本的 Internet Explorer (IE5 和 IE6) return new ActiveXObject("Microsoft.XMLHTTP"); }catch(e){} return false; } } return new XMLHttpRequest(); }
XHR对象的属性以下:web
responseText:响应体算法
responseXML:若是响应内容是”text/xml”或者”application/xml”,这个属性会保存响应数据的XML DOM文档跨域
status:响应的HTTP状态(404, 200之类的)浏览器
statusText:HTTP状态说明,不可靠,由于各个浏览器不同,直接用status状态码最可靠安全
readyState:多用于异步请求,虽然同步请求也能用,但没什么意义,readyState的5个值以下:服务器
0:未初始化。还没调用open方法cookie
1:启动。调用了open没调用send
2:发送。调用了send还没收到响应
3:接收。拿到了部分响应数据
4:完成。拿到了全部数据,而且数据已经可用了
var xhr = getHttpObject(); xhr.onreadystatechange = function(){ if(xhr.readyState === 4){ if(xhr.status >= 200 && xhr.status < 300 || xhr.status === 304){//原本只用检测200成功和304不变但有些浏览器会把200错报成204 //执行callback } else{ //请求失败 } } }
注意:必须在open函数以前设置readystatechange事件处理器,以保证全浏览器兼容
//get请求 xhr.open('get', url, false/true);//初始化,false/true ~ 同步/异步 xhr.send(null);//发送请求,null是为了兼容性 //post请求 xhr.open('post', url, false/true);//同上 xhr.send(str); /* 能够在open后send前设置请求头,好比添加cookie信息 xhr.setRequestHeader(strHeader, strValue); */
注意:服务器对post请求和提交web表单的请求处理方式不一致,但能够经过修改HTTP头来模拟表单提交
但若是要发送表单数据的话,send的参数str必须是通过序列化的表单数据。此时须要模拟实现序列化函数,比较麻烦,JQuery提供了序列化支持,能够直接$(‘#mForm’).serialize()序列化表单
xhr.abort();能够在响应返回前终止请求,abort以后不会再触发事件,不容许再访问xhr的响应相关属性
注意:终止请求后应该解除XHR对象的引用,不建议重用XHR对象(因为内存缘由)
post请求消耗的资源多,数据传输速率也比get请求慢不少
但get请求不安全,并且IE对URI的长度有限制(不超过2048个字节),因此尽可能用get,不行再用post
Cross-Origin Resource Sharing,跨源资源共享,Ajax受同源策略限制,经过一些CORS技术能够打破同源策略限制。例如IE8的XDR对象
其它浏览器经过加强XHR对象实现了对CORS的原生支持:把open函数的url参数设置为绝对URL就行了
因此为了消除歧义,应该在访问本地资源时用相对URL,访问远程资源时用绝对URL
图像Ping
var img = new Image(); img.onload = img.onerror = function(){ //响应返回,执行回调函数 } img.src = url;//一旦设置了src属性,就会当即请求(加载)图片,而不是把img元素插入DOM树后才开始
只能发送get请求,且没法访服务器的响应文本,多用于跟踪用户点击页面或动态广告曝光次数
JSONP
JSON with Padding,支持浏览器与服务器进行双向通讯,且可以直接访问响应文本,但须要服务器端代码的配合,不易肯定请求失败与否,并且从其它域加载代码执行,会存在安全问题
有一篇很不错的介绍跨域技术的博文
Cross-Site Request Forgery,跨站请求伪造,向页面直接插入Ajax代码,不存在同源策略限制,从而伪造请求访问敏感数据。
防范方法有:
要求用SSL链接访问资源
要求每次请求必须附带上特殊算法计算获得的验证码