如何从跨域iframe中的子文档获取父文档中的iframe元素?

时间:2012-11-26 23:42:18

标签: c# internet-explorer mshtml shdocvw

我有相反的代码:获取iframe element的子文档:

var htmlWindow = (element as IHTMLFrameBase2).contentWindow;
if (htmlWindow == null) return null;
// Convert IHTMLWindow2 to IWebBrowser2 using IServiceProvider.
IServiceProvider sp = (IServiceProvider)htmlWindow;
// Use IServiceProvider.QueryService to get IWebBrowser2 object.
Object brws = null;
//brws = 
sp.QueryService(ref IID_IWebBrowserApp, ref IID_IWebBrowser2, out brws);
// Get the document from IWebBrowser2.
SHDocVw.IWebBrowser2 browser = (SHDocVw.IWebBrowser2)(brws);
return (IHTMLDocument2)browser.Document;

我的问题是我该如何做相反的事情呢?考虑到孩子document,我尝试这样做,但我得到一个空frameWindow

Object frameWindow;
IServiceProvider isp = (IServiceProvider)document.parentWindow;
isp.QueryService(ref IID_IWebBrowserApp, ref IID_IHTMLFrameBase, out frameWindow);

以下是供您参考的所有GUID:

private static Guid IID_IWebBrowserApp = new Guid("0002DF05-0000-0000-C000-000000000046");
private static Guid IID_IWebBrowser2 = new Guid("D30C1661-CDAF-11D0-8A3E-00C04FC9E26E");
private static Guid IID_IHTMLFrameBase2 = new Guid("3050F6DB-98B5-11CF-BB82-00AA00BDCE0B");
private static Guid IID_IHTMLFrameBase = new Guid("3050F311-98B5-11CF-BB82-00AA00BDCE0B");
private static Guid IID_IHTMLWindow2 = new Guid("332C4427-26CB-11D0-B483-00C04FD90119");

这是我的IServiceProvider

[ComImport(), ComVisible(true), Guid("6D5140C1-7436-11CE-8034-00AA006009FA"),
InterfaceTypeAttribute(ComInterfaceType.InterfaceIsIUnknown)]
private interface IServiceProvider
{
    [return: MarshalAs(UnmanagedType.I4)]
    [PreserveSig]
    int QueryService(ref Guid guidService, ref Guid riid, [MarshalAs(UnmanagedType.Interface)] out object ppvObject);
}

1 个答案:

答案 0 :(得分:0)

实际上,您无法从主浏览器获取Iframe文档/元素。你必须要执行javascript。在我的情况下,我在目标网站上可以获得jquery,所以我使用了以下快递从内部iframe中获取一些文本。

我这样做了:

   var tmp = browser.Document.InvokeScript("eval", new object[] { "$(\"#iframe_id\").contents().find('#element').html())" });

在你的情况下,如果你真的想用目标iframe中某个元素的html做一些事情,那么你应该实际抓取它的html然后在主浏览器窗口中创建一个空元素并用你的那个更新它的html抓住并做你的东西。

这是我到目前为止找到的唯一方法。