WebBrowser和多线程.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
WebBrowser和多线程

WebBrowser和多线程 我们在做采集软件的时候有些网站通过直接分析html文本是很麻烦的事情在利用WinForm编程的情况下有一种更好的方式当然是分析HtmlDocument然而,这HtmlDoucment并不能直接创建它必须由 WebBroswer控件Navigate生成一个页面后才能取得wb.HtmlDocument然后就可以对HtmlDocument的各元素、标签进行分析。事实上,在采集的时候并不是采集只会采集单个页面这样的话,在主窗体中就可以完成譬如采集一些列表页面,有N多个页那么,一个循环下去,用WebBrowser去响应,那就会导致假死这时候,我们肯定会想到用多线程去做这件事情C#的多线程,大家应该都知道,有STA,MTA两种模式然而,WebBrowser控件却有一个不好的特点那就是:它只支持多线程STA模式例如下面的代码,Thread tread = new Thread(new ParameterizedThreadStart(BeginCatch));tread.SetApartmentState(ApartmentState.STA);tread.Start(url);javascript:void(0);复制代码private void BeginCatch(object obj){ string url = obj.ToString(); WebBrowser wb = new WebBrowser(); wb.ScriptErrorsSuppressed = true; wb.Navigate(url); wb.DocumentCompleted += new WebBrowserDocumentCompletedEventHandler(wb_DocumentCompleted);}javascript:void(0);复制代码需要分析WebBrowser产生 的HtmlDocument时,必须在事件DocumentCompleted里面去操作只有这时候,WebBrowser才算加载完成不过,这只是一个陷阱!!!!WebBrowser有一个特性,那就是在多线程STA的时候,根本就不等到DocumentCompleted的执行也就是无法再进行后面的操作!!!这样的话,我们该如何办呢?也许有人会想:wb.Document.Write(string)方法,如下:private void BeginCatch(object obj){ string url = obj.ToString(); WebBrowser wb = new WebBrowser(); wb.ScriptErrorsSuppressed = true; string htmlcode = GetHtmlSource(url); wb.Document.Write(htmlcode); //执行分析操作 }//WebClient取网页源码private string GetHtmlSource(string Url){ string text1 = ; try { System.Net.WebClient wc = new WebClient(); text1 = wc.DownloadString(Url); } catch (Exception exception1) {} return text1;}javascript:void(0);复制代码但这时候,我们会发现,wb.DocumentText总是没有的当时我也很郁闷,搜索园子里的文章与MSDN,都是可以用DocumentText赋值的但也在网上发现了很多说操作后没有结果的经过努力搜索在园子里发现了一篇有用的文章里提到的一个例子经过测试后发现WebBrowser必须经过Navigate后才会产生Document于是忽,终于可以实现了多线程下面的操作了最终代码如下private void ThreadWebBrowser(string url){ Thread tread = new Thread(new ParameterizedThreadStart(BeginCatch)); tread.SetApartmentState(ApartmentState.STA); tread.Start(url);}private void BeginCatch(object obj){ string url = obj.ToString(); WebBrowser wb = new WebBrowser(); wb.ScriptErrorsSuppressed = true; //在这里Navigate一个空白页面 wb.Navigate(about:blank); string

文档评论(0)

xcs88858 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档