关于Webbrowser针对网银控件显示不正常的一个解决思路。

解决WebBrowser控件加载招行网银页面问题
本文介绍了一个基于IE的WebBrowser控件在加载招行网银页面时遇到的问题及解决方法。通过使用Spy++进行调试发现控件创建失败,并通过Windbg分析确定为尝试执行栈上非可执行代码所致。最终通过关闭数据执行保护解决了问题。
1 假设你在开发一个基于ie的WebBrowser的控件,只是调用WebBrowser接口。

2 打开招行网银页面, https://pbsz.ebank.cmbchina.com/CmbBank_GenShell/UI/GenShellPC/Login/Login.aspx
会发现如下的情况,控件并没有显示出来。



3 用Spy++抓取之后,会发现窗口并没有创建成功,这个时候并没有任何的解决方案。

4 感谢Win8更为严格的检查机制,页面会直接崩溃。
分析Dump,确实是CreateWindow失败了。

5 可以看到,该控件崩溃了,访问栈上的地址时候,写指令违例。
 mov     dword ptr [esp+4],0C82068Ch
WRITE_ADDRESS:  17ad3250 

6如果更细心一点的话,会发现Windbg已经告诉你是怎么一回事了。
Attempt to execute non-executable address 17ad3250
尝试执行不可执行的代码段,而该代码在栈上。


7 查了一下资料, ATL 7.1 或更早的版本确实使用了在栈上面执行代码的机制。而为了兼容性,需要关闭数据执行保护

8 在我们的干净的Demo中,加上/NXCOMPAT:NO后,终于可以工作正常了。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值