利用LoadRunner实现加密测试
2015-12-16 11:35
429 查看
在进行LoadRunner打压时,有时候请求的参数是加密的,而加密的法则是通过调用一段DLL来生成的。这样通过参数化模拟的打压请求就无法达到预期的效果,这时候就需要调用DLL后,拿到DLL的返回值,用返回值来构造打压请求。那么怎么调用DLL呢?
首先说一下调用DLL需要的条件:
1、 VuGen只能识别标准C编译的DLL, 所以使用VC6创建的函数必须在函数开头加上extern "C",它告诉编译器对这个函数按照标准C的方式进行编译。
2、 需要有标准C的导出函数。可以通过Dependency Walker查看:
满足这两点后,就可以在LoadRunner脚本中调用此DLL了。
调用外部DLL的方法有两种:
● (单个脚本中)在脚本中是使用 lr_load_dll 函数。
● (全局设置,所有脚本)通过修改 mdrv.dat 文件实现。
第一种方法,可以直接通过lr_load_dll函数来实现。
这样就可以直接保存返回值用户后续的打压参数了。但是这种方法是单个脚本才能用的,其他脚本不能使用。
第二种方法是全局设置,相当于将dll加载到LoadRunner的DLL库中。所有脚本你都可以调用。
1、将需要的DLL拷贝到LoadRunner安装路径的Bin目录下。
2、修改mdrv.dat文件,找到[lrun_api]节点,在后面加上一句:
WINNT_DLLS=XXX.dll
这样,就不用lr_load_dll函数,直接调用XXX.dll里面的函数了。
另外,在具体通过agent打压时,会发现报如下错误:
Error: CCI security error:You are running under secure mode and the function ci_load_dll is not allowed in this mode.
这是由于远程agent打压机无法加载DLL导致的。解决办法是在添加脚本时,将引用的DLL也添加进来。
首先说一下调用DLL需要的条件:
1、 VuGen只能识别标准C编译的DLL, 所以使用VC6创建的函数必须在函数开头加上extern "C",它告诉编译器对这个函数按照标准C的方式进行编译。
2、 需要有标准C的导出函数。可以通过Dependency Walker查看:
满足这两点后,就可以在LoadRunner脚本中调用此DLL了。
调用外部DLL的方法有两种:
● (单个脚本中)在脚本中是使用 lr_load_dll 函数。
● (全局设置,所有脚本)通过修改 mdrv.dat 文件实现。
第一种方法,可以直接通过lr_load_dll函数来实现。
这样就可以直接保存返回值用户后续的打压参数了。但是这种方法是单个脚本才能用的,其他脚本不能使用。
第二种方法是全局设置,相当于将dll加载到LoadRunner的DLL库中。所有脚本你都可以调用。
1、将需要的DLL拷贝到LoadRunner安装路径的Bin目录下。
2、修改mdrv.dat文件,找到[lrun_api]节点,在后面加上一句:
WINNT_DLLS=XXX.dll
这样,就不用lr_load_dll函数,直接调用XXX.dll里面的函数了。
另外,在具体通过agent打压时,会发现报如下错误:
Error: CCI security error:You are running under secure mode and the function ci_load_dll is not allowed in this mode.
这是由于远程agent打压机无法加载DLL导致的。解决办法是在添加脚本时,将引用的DLL也添加进来。
相关文章推荐
- 用ASP编写的加密和解密类
- VBS脚本加密/解密VBS脚本(简易免杀版1.1)
- BAT加密工具 EncryBat 非编译型bat批处理加密方案与代码
- C#对称加密(AES加密)每次生成的结果都不同的实现思路和代码实例
- SQLServer 2008中的代码安全(一) 存储过程加密与安全上下文
- 实例讲解SQL Server加密功能
- C#实现对文件进行加密解密的方法
- C#实现数据包加密与解密实例详解
- C#最简单的字符串加密解密方法
- C#加密app.config中连接字符串的方法
- C#使用伪随机数实现加密用户密码的方法
- asp MD5加密方式使用建议
- C#对称加密与非对称加密实例
- 浅谈C#中Md5和Sha1两种加密方式
- vbs shellcode转换escape加密
- PHP加密解密字符串汇总
- c#通过DES加密算法加密大文件的方法
- 加密web.config的方法分享
- asp.net的加密解密技巧
- asp.net实现md5加密