繁体   English   中英

为什么我的chrome扩展程序不能使用HTML5 postMessage与我注入的帧进行通信?

[英]Why can't my chrome extension use HTML5 postMessage to communicate with a frame I inject?

所以,我在DomainA上有一个页面,并且,使用Chrome扩展程序,我正在注入一些插入指向DomainB的iframe的javascript。

$("body").append("<iframe id='someFrame' src='http://www.domainB.com' width='300' height='800'></iframe>");

我还向DomainA注入了一些javascript,试图获取iframe的contentWindow。 我想在它上面使用HTML5 postMessage api。

$("body").append("<a class='myLink'>Post Message</a>");
$(".myLink").click(function(){
    var frameElem = document.getElementById("someFrame"); 
    console.log("frameElem: " + frameElem); //succeeds

var contentWin = frameElem.contentWindow;
console.log("contentWin : " + contentWin); //undefined

//can't do this since contentWin is undefined: 
//contentWin.postMessage("data", "*");
});

但是,contentWindow属性未定义。 为什么会这样,我怎么能绕过它呢? 如果我将此扩展代码放在网页中,它本身就可以正常工作。

谢谢!

(原谅蹩脚的jquery / javascript)

我知道回答我自己的问题有点蹩脚,但我做了一些挖掘工作,发现Chromium上存在一个问题: http//code.google.com/p/chromium/issues/detail?id = 20773

我在chrome扩展程序组中找到了此链接: http//groups.google.com/a/chromium.org/group/chromium-extensions/browse_thread/thread/1d4b68f0971ef190/3446a7e82848351c?lnk=gst&q=contentWindow#3446a7e82848351c

我认为这与内容脚本无法访问其父页面的窗口对象的原因相同。 看到这个问题 ,它有一个解决方法的链接。

您需要在根框架中嵌入iframe,该框架将请求发送到客户端框架,然后客户端框架将命令发送回根网站,如以下示例所示。 这被称为“单向管道”黑客: http//msdn.microsoft.com/en-us/library/bb735305.aspx
替代文字

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM