5

背景

  • 几年前,onerror处理程序和跨源脚本标签存在问题,有关此的更多信息

  • 主要浏览器修复了该问题。

  • 知道这是从 CDNed 脚本中检测客户端错误的问题,他们在一定程度上放松了这些限制(firefoxwebkit

实际问题

我在 localhost 上托管一个简单页面,并包含来自不同域(例如“sitea”)的脚本,HTML 如下所示:

<html>
<head>
<script>window.onerror = function(e, f, g) { console.log('err',e,f,g) }</script>
</head>
<body><h2>test</h2>
<script src='http://siteA:8081/one.js' crossorigin='anonymous'></script>
</body>
</html>

上的脚本siteA执行此操作:

var foo; foo.bar;

显然这会抛出,因为 bar 是未定义的。

不幸的是,我仍然在第 0 行遇到“脚本错误”,就像门票中描述的那样。

请注意,我是:

  • 设置跨域属性。

  • 在请求中看到“Origin”标头

  • 将 Access-Control-Allow-Origin 标头设置为“*”并在开发 Web 工具上查看。

我在firefox和chrome都试过了,还是不行。任何人都知道为什么?

4

1 回答 1

3

在 Firefox 20 中为我工作,Chrome从版本 30 开始支持跨域错误报告

您可以看到浏览器确实发送了一个Origin:标头,因为该<script>标记具有一个crossorigin属性,并且错误被正确报告,因为服务器以Access-Control-Allow-Origin: *.

于 2013-06-19T21:36:49.763 回答