qtp ie_hook
今天要讲的内容是注册异类子控件授予强制HOOK,名字有点抽象,简单的说就是在一个QTP可识别的A类插件窗口对象中存在着B类插件的控件对象, 最常见的例子就是在应用程序中内嵌一个Browser对象子控件。说穿了就是内嵌一个浏览器,注意这里的大前提是此应用程序是可以被QTP识别的。那么如 果出现我所说的此类情况,那么QTP是绝对不可能去自动识别此应用程序中的浏览器控件对象的,原因很简单,QTP只把这个应用程序看做是一个A类插件的控 件对象,因此他根本不会去识别它。那么本章就来讲一下如何通过注册异类子控件的方法来强制注入启动hook,简单来看一下。
图1
如图1 是我在。net中建立的一个非常简单的浏览器程序,我们可以看到此应用程序一共只有三个控件,一个是地址文本框,一个是“go”按钮用于提交地址栏, 还有一个就是Browser对象控件,此浏览器是内嵌在.net程序中的。
那么现在我们打开QTP,加载.Net 和 Web插件之后,这里我们首先来看一下spy识别.net程序中的Go按钮。
图2
来看一下QTP是否能够识别浏览器为page对象。我们再使用spy对Browser控件进行捕获。
图3
如 图3,我们发现QTP根本无法识别此Browser对象,直接是抛了个WinObject出来,title还是Internet Explorer_Server,还真是不给面子,明明已经查出是IE了,还不给识别。那既然不给面子,那我们也不用客气,怎么办?直接切入QTP的核心 HOOK配置文件,强制注册应用程序。
精彩部分开始,请注意看下去:
1. 进入到QTP的核心目录: 《安装目录》/bin 下找到 mic.ini (此文件是关键文件)
图4
2. 用记事本打开此INI文件。我们都知道INI格式的都是配置文件,可以直接在里面更改我们需要的配置。
3. 找到[ie_hook]部分段落。
图5
4. 在这一栏的最后添加一行应用程序的 文件名+后缀名 = yes后保存。
图6
5. 修改完毕之后,重启QTP,再次重启刚才的应用程序,此时我们再来看一下spy的结果。
图7
如图7,我们可以看到结果很明显,经过我们的努力,QTP当然也相当的给力,成功把Browser对象识别为Page对象。包括对象库也可以任意添加。
图8
好 了,整个例子就这样完毕了,回头我们再来看一下mic.ini,除了ie_hook外,还有很多其他的配置可以改,有兴趣的朋友也可试试探索下。忘了提 了,其实此方法就是QTP的Register New Browser Control的一个执行过程。但是此方法比它好的地方就很明显了,就是我们可以使用脚本的形式来对ini文件进行配置,而不是需要人工介入去另行注册。 对于移植脚本来说是非常有利的。
最新文章
- Masonry_设置比例
- Struts 1.3(第一例) - Login
- CentOS 搭建LNMP服务器和LAMP服务器
- poj 1274 The Perfect Stall【匈牙利算法模板题】
- Java 内存区域和GC机制-java概念理解
- YII CDbCriteria总结
- JavaScript模板引擎
- iOS强制切换横屏、竖屏
- Struts2第十二篇【模型驱动】
- php中向前台js中传送一个二维数组
- [Python Study Notes]实现对键盘控制与监控
- R语言︱机器学习模型评价指标+(转)模型出错的四大原因及如何纠错
- XShell上传文件到Linux服务器上
- PC逆向之代码还原技术,第二讲寻找程序入口点
- [InstFiles]在Inno中打包隐藏和系统文件的头文件
- Ubuntu + 坚果云
- python functiontools模块中的 wraps
- CentOS查找目录或文件
- ZooKeeper的安装和API
- 常用的SQL调优
热门文章
- 'gbk' codec can't encode character '\xa0' in position 34: illegal multibyte sequence
- 2个canvas叠加运用(时钟例子)
- Yii2之事件处理
- HDU - 1728 逃离迷宫 【BFS】
- 使用MAVEN手动创建web项目
- 美团offer
- pygame躲敌人的游戏
- H5 input默认数字键盘,显示为密码格式
- X-Scan扫描端口80,443提示http TRACE 跨站攻击漏洞解决办法
- Delphi UniDAC 通过http协议连接数据库的设置