如何使LoadRunner实现加密测试

来源:互联网 发布:淘宝无理由退货规则 编辑:程序博客网 时间:2024/06/07 06:35

在进行LoadRunner打压时,有时候请求的参数是加密的,而加密的法则是通过调用一段DLL来生成的。这样通过参数化模拟的打压请求就无法达到预期的效果,这时候就需要调用DLL后,拿到DLL的返回值,用返回值来构造打压请求。那么怎么调用DLL呢?

首先说一下调用DLL需要的条件:

1、 VuGen只能识别标准C编译的DLL 所以使用VC6创建的函数必须在函数开头加上extern "C",它告诉编译器对这个函数按照标准C的方式进行编译。

2、 需要有标准C的导出函数。可以通过Dependency Walker查看:

640?wx_fmt=png&tp=webp&wxfrom=5

满足这两点后,就可以在LoadRunner脚本中调用此DLL了。

调用外部DLL的方法有两种:

● (单个脚本中)在脚本中是使用 lr_load_dll 函数。

● (全局设置,所有脚本)通过修改 mdrv.dat 文件实现。

第一种方法,可以直接通过lr_load_dll函数来实现。


640?wx_fmt=png&tp=webp&wxfrom=5

这样就可以直接保存返回值用户后续的打压参数了。但是这种方法是单个脚本才能用的,其他脚本不能使用。

第二种方法是全局设置,相当于将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也添加进来。

640?wx_fmt=png&tp=webp&wxfrom=5

0 0