本文共 2870 字,大约阅读时间需要 9 分钟。
本文内容来源:
(由于我在本地打不开此链接,所以就转载过来。供大家一起学习)
同源策略限制了一个源(origin)中加载文本或脚本与来自其它源(origin)中资源的交互方式。
如果两个页面拥有相同的协议(protocol),端口(如果指定),和主机,那么这两个页面就属于同一个源(origin)。
下表给出了相对http://store.company.com/dir/page.html同源检测的示例:
URL | 结果 | 原因 |
http://store.company.com/dir2/other.html | 成功 |
|
http://store.company.com/dir/inner/another.html | 成功 |
|
https://store.company.com/secure.html | 失败 | 协议不同 |
http://store.company.com:81/dir/etc.html | 失败 | 端口不同 |
http://news.company.com/dir/other.html | 失败 | 主机名不同 |
参见.
来自about:blank,javascript:和data:URLs中的内容,继承了将其载入的文档所指定的源,因为它们的URL本身未指定任何关于自身源的信息。
在处理同源策略的问题上,IE存在两个主要的不同之处。
这些例外是非标准的,其它浏览器也未做出支持,但会助于开发基于window RT IE的应用程序。
页面可以改变本身的源,但会受到一些限制。脚本可以设置 的值为当前域的一个后缀
在同源策略中有一个例外,脚本可以设置 的值为当前域的一个后缀,如果这样做的话,短的域将作为后续同源检测的依据。例如,假设在http://store.company.com/dir/other.html 中的一个脚本执行了下列语句:
document.domain = "company.com";
这条语句执行之后,页面将会成功地通过对 http://company.com/dir/page.html 的同源检测。而同理,company.com 不能设置 document.domain 为othercompany.com.
浏览器单独保存端口号。任何的赋值操作,包括document.domain = document.domain都会以null值覆盖掉原来的端口号。因此company.com:8080页面的脚本不能仅通过设置document.domain = "company.com"就能与company.com通信。赋值时必须带上端口号,以确保端口号不会为null。
附注:使用document.domain来安全是让子域访问其父域,需要同时将子域和父域的document.domain设置为相同的值。必须要这么做,即使是简单的将父域设置为其原来的值。没有这么做的话可能导致授权错误。
同源策略控制了不同源之间的交互,例如在使用 或 标签时则会受到同源策略的约束。交互通常分为三类:
以下是一些可以跨域内嵌的资源示例:
使用 来实现跨域访问。
Javascript的APIs中,如 , , 和 允许文档间直接相互引用。当两个文档的源不同时,这些引用方式将对 和 对象的访问添加限制。可以使用 作为替代方案,提供跨域文档间的通讯。
存储在浏览器中的数据,如和,以源进行分割。每个源都拥有自己单独的存储空间,一个源中的Javascript脚本不能对属于其它源的数据进行读写操作。
属性可以用来临时存储数据,可以跨域访问。
Cookies使用不同的源定义方式。一个页面可以为本域和任何父域设置cookie,只要是父域不是公共后缀(public suffix)即可。Firefox和Chrome使用决定一个域是否是一个公共后缀(public suffix)。不管使用哪个协议(HTTP/HTTPS)或端口号,浏览器都允许给定的域以及其任何子域名(sub-domains)来访问cookie。设置cookie时,你可以使用Domain,Path,Secure,和Http-Only标记来限定其访问性。读取cookie时,不会知晓它的出处。尽管使用安全的https连接,任何可见的cookie都是使用不安全的连接设置的。