Мне удалось решить такую проблему.
Вам понадобятся сторонние сборки:
- FiddlerCore : будет действовать как http-прокси,встроенный в ваше приложение
- Awesomium.net : элемент управления WebBrowser, который работает с механизмом хрома.Я выбрал этот движок, потому что он позволяет указывать прокси-сервер только для приложения.
Идея, как вы предполагаете, состоит в том, чтобы создать прокси-сервер в памяти и перенаправить управление веб-браузером.на этот прокси.
Затем 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");
}
}
Вам потребуется добавить некоторые сантехники в это приложение, чтобынаправить и проанализировать запрос от приложения к бизнес-классу, но это выходит за рамки этого вопроса.