我正在使用 zClip:http://www.steamdev.com/zclip/ (并尝试了 ZeroClipboard 也得到了同样的结果)
当我在 iframe 中使用它时,我收到此 javascript 错误/警告:
Unsafe JavaScript attempt to access frame with URL file://localhost/Users/me/Desktop/test.html from frame with URL http://localhost:3000/a. The frame requesting access has a protocol of 'http', the frame being accessed has a protocol of 'file'. Protocols must match.
file://localhost/Users/me/Desktop/test.html 是我设置的一个本地文件,里面有一个 iframe,它加载了我的小部件。复制按钮位于小部件中。
尽管有错误,但复制功能似乎可以完美运行,所以我不确定它为什么会出现,并且想清理它。
这是我在小部件中的咖啡/javascript:
btn = $('#'+id)
btn.zclip
path: '/flash/ZeroClipboard.swf',
copy: btn.data('copy')
这只是标准的东西。当我评论 btn.zlip
block 时,错误消失了,所以它似乎是那一行。
我假设 zeroclip javascript 中有一些东西在 iframe 之外冒泡到父级,但我找不到任何东西。想知道是否还有其他人解决了这个问题。谢谢!
最佳答案
只要在跨域iframe中嵌入了一个flash对象,就会抛出一个跨域异常。
例如,查看这个嵌入了 iFrame 的 jsfiddle:http://jsfiddle.net/bkCdB/
<object width="420" height="315"><param name="movie" value="http://www.youtube.com/v/6V_DsL1x1uY?version=3&hl=en_US"></param><param name="allowFullScreen" value="true"></param><param name="allowscriptaccess" value="always"></param><embed src="http://www.youtube.com/v/6V_DsL1x1uY?version=3&hl=en_US" type="application/x-shockwave-flash" width="420" height="315" allowscriptaccess="always" allowfullscreen="true"></embed></object>
关于javascript - ZeroClipboard/zlip 在 iframe 中导致不安全的 Javascript 警告,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13714501/