. net web浏览器控件捕获下载

本文关键字:下载 控件 web 浏览器 net | 更新日期: 2023-09-27 18:14:15

如何捕获web浏览器自动下载的下载文件(如。html, png等)

例如,如果一个网站通过javascript每30秒下载一个html文件,我如何使用web浏览器控件捕获这个html ?

. net web浏览器控件捕获下载

我的方法是

步骤1抓取脚本元素的内容(具有html文件路径的变量)

//using HtmlAgilityPack
HtmlAgilityPack.HtmlDocument doc = new HtmlAgilityPack.HtmlDocument();
doc.LoadHtml(html);
//Considering first script tag (you need to check your decentands)
var script = doc.DocumentNode.Descendants()
                             .Where(n => n.Name == "script")
                             .First().InnerText; 
// Return the data of the spect and stringify it into a proper JSON object
var engine = new Jurassic.ScriptEngine();
var result = engine.Evaluate("(function() { " + script + " return spects; })()");
var json = JSONObject.Stringify(engine, result);
Console.WriteLine(json);
Console.ReadKey();

步骤2:在另一个浏览器控件或相同的浏览器控件中打开html页面

WebBrowser wb2 = new WebBrowser();
wb2.AllowNavigation = true;
wb2.Navigate(jsVariableAsString);

步骤3:保存浏览器页面

var html = wb2.DocumentText.ToString();

或wb2.ShowSaveAsDialog ();