【发布时间】:2015-09-21 13:32:19
【问题描述】:
当我尝试将我的应用部署到 Android 系统高于 5.0.0 (Lollipop) 的设备上时,我不断收到这些错误消息:
07-03 18:39:21.621: D/SystemWebChromeClient(9132): file:///android_asset/www/index.html: 第 0 行:拒绝加载 脚本'http://xxxxx',因为它违反了以下内容 安全策略指令:“script-src 'self' 'unsafe-eval' '不安全内联'”。07-03 18:39:21.621: I/chromium(9132): [INFO:CONSOLE(0)] "拒绝加载脚本 'http://xxx' 因为它 违反以下内容安全策略指令:“script-src 'self' 'unsafe-eval' 'unsafe-inline'"。
但是,如果我将其部署到 Android 系统为 4.4.x (KitKat) 的移动设备上,则安全策略适用于默认策略:
<meta http-equiv="Content-Security-Policy" content="default-src 'self' data: gap: https://ssl.gstatic.com 'unsafe-inline' 'unsafe-eval'; style-src 'self' 'unsafe-inline'; media-src *">
然后我想,也许,我应该改成这样:
<meta http-equiv="Content-Security-Policy" content="script-src 'self' 'unsafe-eval' 'unsafe-inline'; object-src 'self'; style-src 'self' 'unsafe-inline'; media-src *">
基本上,这两个选项都不适合我。我该如何解决这个问题?
【问题讨论】:
-
与我的问题非常相似。我无法检索 JSON 文件,“因为它违反了以下内容安全策略指令:“connect-src 'self'””
-
@MichaelR 如果您想通过 JS 从 API 中检索一些 JSON 信息,例如 tampermonkey 插件或其他所有内容,您可以使用此插件 chrome.google.com/webstore/detail/disable-content-security/… 并在您想要获取某些内容时禁用 CSP 检查。它虽然不安全,但在某些情况下它可能会起作用。我在此处发布此答案是因为我正在寻找我的错误,并且此主题首先在 Google 中显示。
标签: javascript android cordova content-security-policy