You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
function success(text){
var textarea = document.getElementById('response-text');
textarea.value = text;
}
function fail(err){
var textarea = document.getElementById('response-text');
text.value = 'Error:' + err;
}
var xhr = new XMLHttpRequest(); //创建XMLHttpRequest对象
AJAX(Asynchronous JavaScript And Xml) 是JavaScript执行异步网络请求
用户点击“Submit”按钮,表单开始提交,浏览器就会刷新页面,web的运作原理:一次HTTP请求对应一个页面
要让用户留在当前页面,同时发送请求,要用JavaScript实现,接收到数据后,再用JavaScript更新页面
实现AJAX主要依靠XMLHttpRequest对象:
必须在调用open之前指定onreadystatechange事件处理程序才能确保跨浏览器兼容性
IE以及低版本IE,XMR对象是通过MSXML库中的一个ActiveX对象实现的。
所以在IE中可能会遇到三种不同的XHR对象:
MSXML2.XMLHttp、MSXML2.XMLHttp.3.0、MSXML2.XMLHttp.6.0
所以封装一个函数来创建XHR对象,兼容IE版本
CORS(Cross-Origin Resource Sharing)跨域资源共享
Ajax同信限制:跨域安全策略;
XHR对象只能访问与包含它的页面位于同一个域中的资源:
1、域名要相同(www.example.com和example.com不同),
2、协议要相同(http和https不同),
3、端口号要相同(默认是:80端口,它和:8080就不同)。
CORS定义了在访问跨域资源时,浏览器和服务器应该怎样沟通,CORS的思想是使用自定义的HTTP头部让浏览器与服务区进行沟通,从而决定响应是成功还是失败
比如一个简单的GET或POST请求,它没有自定义的头部,而主题内容是text/plain。在发送该请求时需要给它加一个额外的头部,包含请求页面的源信息(协议、域名和端口),服务器根据该头部信息决定是否给予响应,Origin头部示例:
Origin : http://www.fanwalker.com
如果服务器接收该请求,会在Access-Control-Allow-Origin头部中回发相同的源信息。例如:
Acess-Control-Allow-Origin: http://www.fanwalker.com
如果没有这个头部或不匹配源信息,浏览器会驳回请求。这里注意请求和响应都不包含cookie信息
IE对CORS的实现
IE8中引入了XDR(XDomainRequest)类型,可以实现安全的跨域通信,XDR对象的使用方法与XHR对象相似:
GET请求
POST请求
更多详细的介绍:HTTP访问控制(CORS)
The text was updated successfully, but these errors were encountered: