WPF webbrowser的LoadCompleted事件

时间:2011-08-22 18:00:58

标签: c# .net wpf wpf-controls

WPF webbrowser的LoadCompleted事件何时会触发? 此事件是否等待在aspx页面中完成任何ajax调用。

我有一个wpf应用程序,其中一个webbrowser控件放在一个窗口表单和一个使用Navigate方法加载的网页上。即使某些ajax调用未初始化/等待,LoadCompleted事件也会触发。

请建议任何在加载网页100%后触发的事件,包括所有ajax电话。

3 个答案:

答案 0 :(得分:1)

我已经能够解决这个问题了。

您需要一些第三方程序集:

  1. FiddlerCore:将作为嵌入在您的应用程序中的http代理
  2. Awesomium.net:WebBrowser控件,与chrome引擎配合使用。我选择此引擎,因为它允许仅为应用程序指定代理服务器。
  3. 您认为,这个想法是创建一个内存代理服务器,并将您的Web浏览器控件重定向到此代理。

    然后,FiddlerCore发布了一些事件,您可以分析请求/响应,尤其是正文。

    当它作为代理时,代理会路由所有通信,包括Ajax调用,Flash调用等。

    如果可以提供帮助,可以使用一个小代码来帮助我对此行为进行原型设计:

    App.cs:

    /// <summary>
    /// Interaction logic for App.xaml
    /// </summary>
    public partial class App : Application
    {
        protected override void OnStartup(StartupEventArgs e)
        {
            BootStrap();
            base.OnStartup(e);
        }
    
        private void BootStrap()
        {
            SetupInternalProxy();
            SetupBrowser();
        }
    
        private static void SetupBrowser()
        {
            // We may be a new window in the same process.
            if (!WebCore.IsRunning)
            {
                // Setup WebCore with plugins enabled.
                WebCoreConfig config = new WebCoreConfig
                {
                    ProxyServer = "http://127.0.0.1:" + FiddlerApplication.oProxy.ListenPort.ToString(),
                    EnablePlugins = true,
                    SaveCacheAndCookies = true
                };
                WebCore.Initialize(config);
            }
            else
            {
                throw new InvalidOperationException("WebCore should be already running");
            }
        }
    
        private void SetupInternalProxy()
        {
            FiddlerApplication.AfterSessionComplete += FiddlerApplication_AfterSessionComplete;
            FiddlerApplication.Log.OnLogString += (o, s) => Debug.WriteLine(s);
    
            FiddlerCoreStartupFlags oFCSF = FiddlerCoreStartupFlags.Default;
            //this line is important as it will avoid changing the proxy for the whole system.
            oFCSF = (oFCSF & ~FiddlerCoreStartupFlags.RegisterAsSystemProxy);
    
            FiddlerApplication.Startup(
                0,
                oFCSF
                );
        }
    
        private void FiddlerApplication_AfterSessionComplete(Session oSession)
        {
            Debug.WriteLine(oSession.GetResponseBodyAsString());
        }
    }
    

    MainWindow.xaml:

    <Window
            xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
            xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
            xmlns:local="clr-namespace:WpfApplication1" 
            xmlns:Custom="http://schemas.awesomium.com/winfx" 
            x:Class="WpfApplication1.MainWindow"
            Title="MainWindow" Height="350" Width="525" Loaded="MainWindow_Loaded">
        <Grid>
    
            <Custom:WebControl Name="browser"/>
    
        </Grid>
    </Window>
    

    最后,MainWindow.xaml.cs:

    public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();
        }
    
        private void MainWindow_Loaded(object sender, RoutedEventArgs e)
        {
            browser.LoadURL("http://google.fr");
        }
    }
    

    您必须向此应用程序添加一些管道,以便将应用程序中的请求路由和分析到业务类,但这超出了此问题的范围。

答案 1 :(得分:0)

documentation for the LoadComplete event州:

  

导航到的文档已完成下载时发生。

这意味着当网址下载完成后会触发。它并不意味着任何引用的项都会触发事件(图像,脚本等)。

此外,除非你在调用Web服务器时通知JavaScript引擎本身(我不知道你能做什么),否则无法保证它是一个Ajax调用;调用没有标准,通常对Ajax的调用在您使用的各种库中是不同的。

例如jQuery使用ajax() method,而scriptalicious在内部包装调用,并且没有为您提供直接进行Ajax调用的方法。

或者,您可以直接使用XMLHttpRequest对象进行调用。

即使您可以将其缩小到使用XMLHttpRequest的调用,您也不会知道哪些调用是针对Ajax的;可以调用的URL不表示它们是否是Ajax,也不返回内容类型(纯文本,XML,JSON)。

答案 2 :(得分:-2)

如果您了解.NET Web模型的以下页面生命周期,您将获得更大的了解。

  1. Page_PreInit
  2. 列表项
  3. Page_Init
  4. Page_InitComplete
  5. Page_PreLoad
  6. 的Page_Load
  7. 控制事件
  8. Page_LoadComplete
  9. Page_PreRender
  10. SaveViewState
  11. Page_Render
  12. 激发Page_Unload