CORS通信(跨域源资源共享)

跨域源资源共享

1.CORS:跨域资源共享,跨域源资源共享。默认情况下,XHR对象只能访问它包含它的页面位于一个域中的资源。

首先什么叫做跨域?当请求页面的协议,域名,端口中存在任意一个与XHR所在对象的不同的请求即跨域请求。

我们知道,在进行Ajax的请求的时候要求xhr.open(“获取”,网址,真实)中的URL必须与当前页面的协议,域名,端口相同,

比如,本地url是http://www.study.com而请求的url是https://www.study.com,则协议不同,称为跨域

       本地url是http://www.study.com请求的url是https://www.studys.com,则主域名不同,称为span域

        本地url是http://www.study:8080请求的url是https://www.study:8888,则端口不同,称为span域

本地主机与127.0.0.1虽然都指的是本机,但是也称为跨域

但是有时候跨域请求对于某些浏览器应用程序也是合理的。

因此CORS定义了在必须访问跨源资源时,浏览器与服务器之间应该如何沟通。

其核心思想就是使用自定义的HTTP头部让浏览器与服务器进行沟通,从而决定请求或响应是应该成功还是失败。

比如一个GET请求,它没有自定义的头部,给它添加一个额外的产地头部,其中包含请求页面的源信息,

包括协议端口以及域名。

注意:如果没有这个头部或者有这个头部但是原信息不匹配,浏览器就会驳回请求,请求和响应都不包含的cookie信息

IE对CORS(跨域源资源共享)的实现

XDR对象:实现安全可靠的跨域通信,其安全机制部分实现了CORS规范以下是XDR与XHR不同之处:

  • cookies不会随请求发送,也不会随响应返回
  • 只能设置请求头部信息中的内容类型字段
  • 不能访问响应头部信息
  • 只支持GET和POST请求

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值