12

我花了最后 3 天的时间研究如何使用 XMLHttpRequest 进行跨域请求。最好的选择确实是我已经在使用的 JSONP。

但是我仍然有一个问题,我无法在任何地方找到答案。我阅读了数百篇帖子(包括 SO),但没有人有一个很好的可靠答案(有很好的参考)。希望这里有人可以提供帮助。

话虽如此,我在许多网站上读到,由于安全原因,我无法从域 aaa.com 向 bbb.com 发出 Ajax 请求并获取我想要的数据。这很清楚,我对此毫无疑问。但问题是当我在本地主机中运行下面的代码时(所以我的域是“本地主机”,我不应该能够从另一个域请求任何数据)。

xhReq = new XMLHttpRequest();
xhReq.open("GET","http://domain.com?parameter",true);
xhReq.send(null);

当我检查 Firebug Net 选项卡时,我意识到请求没有被阻止!这是明确要求的。我简直不敢相信。所以我在 domain.com/log.php 中创建了一个文件,我可以在其中记录任何访问我的域的请求。令人惊讶的是,我触发 localhost 的所有请求都在访问我的 domain.com。当我尝试获取响应时,由于我的 Chrome 和 FIrebug 浏览器的原始策略相同,我真的无法得到它。但是,尽管我无法操纵响应者,但请求确实到达了网络服务器,这让我感到非常惊讶。

更令人惊讶的是,如果 domain.com/log.php 生成了 1MB 的巨大响应,我的萤火虫向我展示了浏览器确实从网络服务器下载了所有 1MB,最后它按预期显示了一条消息“拒绝访问”。那么,如果同源策略禁止读取该数据,为什么还要下载所有文件。

最后,令我惊讶的是,我阅读的所有网站和规范都非常清楚地表明,当目标域与源域不匹配时,使用 Ajax 阻止了请求。但显然,通过我的实验,请求正在完成,尽管我无法访问响应数据。

让我感到不安的是,它可能会打开一个巨大的安全漏洞,一个每天有数千次浏览的网站可以运行这 3 行代码,并在一个不友好的网站上引发巨大的 Ddos 攻击,只是让用户请求另一个网站的页面间隔很小,因为浏览器不会阻止请求。

我在 IE 7、8 和 9 以及 Chrome 最新版本和 Firefox 最新版本中测试了这个脚本,并且行为是相同的:请求完成,浏览器下载所有响应,但无法执行 SOP。

希望有人可以向我解释为什么规格如此错误或我理解错误!

4

2 回答 2

3

发生这种情况是因为通过评估从服务器返回的以下访问控制标头值,在客户端(浏览器)上应用了相同的源策略:

  • 访问控制允许来源
  • 访问控制允许方法
  • 访问控制允许标头

如您所见,请求必须首先在服务器上完成,以便浏览器检查返回的标头。这正是您的请求在服务器上执行的原因。

您可以查看A. Barth 的同源政策原则

于 2013-11-04T11:20:10.840 回答
3

请参阅bobince在类似问题上的回答:

根据 XMLHttpRequest 级别 2,浏览器允许在没有预检的情况下发送跨域 GET,但除非远程域选择加入,否则不允许从响应中读取结果。这里没有其他漏洞,因为您已经可以导致通过多个更基本的接口获取要发送的任意 URL(包括查询字符串,就其价值而言)。

例如,您始终能够创建一个元素,并将其 src 设置为远程域上的地址;取消这种跨域能力会破坏很多现有的网络。

有关的:

于 2013-12-03T01:32:38.497 回答