firefox 扩展 opendialog opener null
firefox extension opendialog opener null
我有一个扩展程序可以帮助它的网站打开一个包含内容的对话框。 childwindow需要操作开启器window(重新加载parent/opener的内容)。
因此,child window 尝试执行如下代码:
parent.opener.location.reload();parent.close();
或
parent.opener.document.forms[0].hdReload.value="false";
parent.opener.document.forms[0].submit();
如何让 child window 以这种方式与 parent 以这种方式通信?
附带说明一下,我如何限制访问,以便从 ip X 加载的代码可以打开一个 window 内容来自 ip X?
这与有关模态windows。
编辑 1:
首先在 add-on
中尝试了此代码
window.openDialog(url,name,features,event.target.ownerDocument);
并且在 child window 中我可以通过
引用开场白 window
window.arguments[0];
但是childwindow又会加载另外一个文档,貌似childwindow中加载的第二个文档没有window.arguments.
我猜当 child window 加载另一个文档时它们被删除了。
如果您使用的是 SDK 的 open()
,您可以传递父级 window,子级可以使用 window.parent
属性。
如果 windows 在同一个域中并因此共享会话存储,您可以使用 StorageEvents 让它们相互通信。
在 window 上安装事件侦听器并写入另一个 window 中的存储,它们将能够以这种方式传递消息并相互作用。
但是 IP X/Y 表明它们来自不同的来源,但是如果您可以控制网络,您可以通过将这些 IP 映射到公共域作为子域然后设置 document.domain
到基域放宽同源政策。
如果两者都不是一个选项,您可以将一个 window 的 window 对象注入到另一个 window 的上下文中,这样他们就可以使用 window.postMessage(),但我认为由于安全障碍,这可能会失败。
最后一个选项是这样退回邮件:Window A <-> Addon <-> Window B。这可以通过让插件代码使用 .postMessage
将数据发送到 window 本身,然后 window 通过向其自身发送另一条消息进行回复,插件已为其安装了特权事件侦听器。如果您使用的是 SDK,您还必须通过端口 API 反弹它,因此将涉及多个间接层。
我有一个扩展程序可以帮助它的网站打开一个包含内容的对话框。 childwindow需要操作开启器window(重新加载parent/opener的内容)。
因此,child window 尝试执行如下代码:
parent.opener.location.reload();parent.close();
或
parent.opener.document.forms[0].hdReload.value="false";
parent.opener.document.forms[0].submit();
如何让 child window 以这种方式与 parent 以这种方式通信?
附带说明一下,我如何限制访问,以便从 ip X 加载的代码可以打开一个 window 内容来自 ip X?
这与
编辑 1: 首先在 add-on
中尝试了此代码window.openDialog(url,name,features,event.target.ownerDocument);
并且在 child window 中我可以通过
引用开场白 windowwindow.arguments[0];
但是childwindow又会加载另外一个文档,貌似childwindow中加载的第二个文档没有window.arguments. 我猜当 child window 加载另一个文档时它们被删除了。
如果您使用的是 SDK 的 open()
,您可以传递父级 window,子级可以使用 window.parent
属性。
如果 windows 在同一个域中并因此共享会话存储,您可以使用 StorageEvents 让它们相互通信。 在 window 上安装事件侦听器并写入另一个 window 中的存储,它们将能够以这种方式传递消息并相互作用。
但是 IP X/Y 表明它们来自不同的来源,但是如果您可以控制网络,您可以通过将这些 IP 映射到公共域作为子域然后设置 document.domain
到基域放宽同源政策。
如果两者都不是一个选项,您可以将一个 window 的 window 对象注入到另一个 window 的上下文中,这样他们就可以使用 window.postMessage(),但我认为由于安全障碍,这可能会失败。
最后一个选项是这样退回邮件:Window A <-> Addon <-> Window B。这可以通过让插件代码使用 .postMessage
将数据发送到 window 本身,然后 window 通过向其自身发送另一条消息进行回复,插件已为其安装了特权事件侦听器。如果您使用的是 SDK,您还必须通过端口 API 反弹它,因此将涉及多个间接层。