乐闻世界logo
搜索文章和话题

How to create a worker in a sandboxed iframe?

7 个月前提问
6 个月前修改
浏览次数25

1个答案

1

当您在沙盒环境中的iframe里创建Worker时,通常会遇到安全限制,因为浏览器的同源策略会阻止不同源之间的脚本交互。如果iframe的内容不是从同一个源加载的,那么通常不会允许这个iframe创建Worker。但是,可以通过一些方法来规避这些限制。

以下是在沙盒iframe中创建Worker的几种方法:

1. 同源策略下的Worker创建

如果iframe和父页面来自同一个源,那么你可以直接在iframe中创建Worker。这种情况下,即使iframe有沙盒属性(sandbox),只要没有设置allow-scripts,脚本仍然能够正常运行。

html
<!-- 父页面 --> <iframe src="same-origin-iframe.html" sandbox="allow-scripts"></iframe>
javascript
// same-origin-iframe.html 中的脚本 var worker = new Worker('worker.js');

2. 使用Blob URL创建Worker

即使iframe有沙盒属性,你也可以通过创建一个Blob URL来间接创建Worker。这样做可以绕过文件路径的限制,允许你在沙盒环境中执行Worker代码。

html
<!-- 沙盒iframe --> <script> // 假设沙盒iframe已经设置了allow-scripts var blob = new Blob(["self.onmessage = function(e) { self.postMessage('Worker: ' + e.data); }"], { type: 'application/javascript' }); var worker = new Worker(URL.createObjectURL(blob)); worker.onmessage = function(e) { console.log(e.data); // 输出从Worker传回的数据 }; worker.postMessage('Hello'); // 向Worker发送数据 </script>

这种方法的优点是即使iframe受到严格的沙盒限制,你仍然可以在其中创建Worker

3. 使用Data URL来创建Worker

尽管大部分现代浏览器不允许从非同源的iframe内使用Data URL来创建Worker,但理论上这种方法是可行的。这种方法和Blob URL类似,但已经被许多浏览器出于安全考虑所禁止。

javascript
// 这种方法可能不被所有浏览器支持 var worker = new Worker('data:application/javascript;base64,' + btoa("self.onmessage = function(e) { self.postMessage('Worker: ' + e.data); }"));

注意:

在使用这些方法时,你需要确保遵守浏览器的安全限制,并且不会因为跨域脚本而引入潜在的安全风险。一般来说,最好的做法是尽量避免在沙盒iframe中执行复杂的脚本,除非你完全控制了加载的内容,并且清楚知道自己在做什么。在任何情况下,确保沙盒iframe中的代码安全性是很重要的。

2024年6月29日 12:07 回复

你的答案