问题描述
我似乎无法缓存我的 JS 文件。
一个简单的测试:
index.html
<iframe src="iframe.html" sandBox="allow-scripts"></iframe>
iframe.html
<!DOCTYPE html>
<html lang="en">
<head>
<Meta charset="utf-8" />
<title>Test</title>
<Meta http-equiv="Content-Security-Policy" content="default-src 'self'; script-src s3.objectstorage.com;" />
</head>
<body>
<div id="root"></div>
<script src="http://s3.objectstorage.com/blah.js"></script>
</body>
</html>
如果我将沙箱属性更改为包含 allow-same-origin
,缓存就会开始工作。但是,我将加载不受信任的 JS 文件,因此我不允许这样做。
我的选项是什么,以便缓存我的 JS 文件?
更新 1 看起来我可能被迫将我的原始 JS 从父级下载到 html blob 中,然后引用 iframe 的 blob url。看起来不优雅,但明天会尝试。
更新 2 在 iframe 中加载似乎没有足够的解决方案。我必须用注入的脚本生成一个 html 文件。然后,我在 iframe src 中加载 html 文件。这做了一个磁盘缓存,这似乎足以满足我的目的,并保持 iframe 的安全性。
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)