代码改变世界

在ASP.NET服务器端过程中使用WebBrowser的注意事项

2010-08-01 13:21  Nana's Lich  阅读(6143)  评论(7编辑  收藏  举报

昨天刚刚完成了一个从网页上提取内容的ASP.NET程序。因为目标网页内容比较复杂,所以采用了WebBrowser来代替WebClient。

 

但是,在本地写好的程序,放到了服务器上就停止工作了,也找不到任何异常提示……

在浪费了十几个小时的人生之后,终于发现是因为缺少了引用的程序集——为了处理网页上较为复杂的网页元素,我在程序中使用了MSHTML中声明的接口,然而不知道出于什么样的原因,在项目的引用列表中MSHTML被标记为复制到本地,发布到服务器上的时候自然也不会包含。更有趣的是,期间我编写WinForms应用程序来检验程序逻辑,放到服务器上运行时也没有任何加载错误,而是单纯地不能使用使用了来自MSHTML的接口的过程,害我以为是事件处理过程哪里写错了……

 

另一个需要注意的事情是:

有文章指出在ASP.NET中使用WebBrowser最重要的条件是使用STA线程模型,然后使用System.Forms.Application.Run来创建消息循环;文章中还说,对于ASP.NET来说WinForm窗体是不必要的,所以System.Forms.Application.Run(new System.Forms.ApplicationContext())就可以了——但经实际测试,在Windows Server 2003 + IIS6上运行的话,如果WebBrowser并没有创建在窗体上,则在发生跳转时不会引发DocumentComplated事件;而在Windows 7+WebDev Server上是不会观察到这种现象的。

 

 

除了WebBrowser以外,还有一些关于WinForms的发现:

在Load事件中调用Hide方法可能没有效果,而放在Shown中就可以了——但用户会观察到窗体一闪而过。

覆盖SetVisibleCore可以阻止主窗体显示,但也会导致很多事件不能正常触发。