LoadRunner 调用dll方法

本文主要介绍简单DLL的编写方法及在LoadRunner中局部调用与全局调用DLL方法。

1.动态链接库的编写

在Visual C++6.0开发环境下,打开FileNewProject选项,可以选择Win32 Dynamic-Link Library建立一个空的DLL工程。

DLL必须有一个入口点,这就象C语言MAIN函数一样。在Non-MFC DLL中DllMain是一个缺省的入口函数,你不需要编写自己的DLL入口函数,用这个缺省的入口函数就能使动态链接库被调用时得到正确的初始化。如果应用程序的DLL需要分配额外的内存或资源时,或者说需要对每个进程或线程初始化和清除操作时,需要在相应的DLL工程的.CPP文件中对DllMain()函数按照下面的格式书写。

BOOL APIENTRY DllMain(HANDLE hModule,DWORD ul_reason_for_call,LPVOID lpReserved)

{

switch( ul_reason_for_call )

{

case DLL_PROCESS_ATTACH:

break;

case DLL_THREAD_ATTACH:

break;

case DLL_THREAD_DETACH:

break;

case DLL_PROCESS_DETACH:

break;

default:

break;

}

return TRUE;

}

参数中,hMoudle是动态库被调用时所传递来的一个指向自己的句柄(实际上,它是指向_DGROUP段的一个选择符);ul_reason_for_call是一个说明动态库被调原因的标志,当进程或线程装入或卸载动态链接库的时候,操作系统调用入口函数,并说明动态链接库被调用的原因,它所有的可能值为:DLL_PROCESS_ATTACH:进程被调用、DLL_THREAD_ATTACH:线程被调用、DLL_PROCESS_DETACH:进程被停止、DLL_THREAD_DETACH:线程被停止;lpReserved为保留参数。到此为止,DLL的入口函数已经写了,剩下部分的实现也不难,你可以在DLL工程中加入你所想要输出的函数或变量了。

我们已经知道DLL是包含若干个函数的库文件,应用程序使用DLL中的函数之前,应该先导出这些函数,以便供给应用程序使用。要导出这些函数有两种方法,一是在定义函数时使用导出关键字_declspec(dllexport),另外一种方法是在创建DLL文件时使用模块定义文件.Def。需要读者注意的是在使用第一种方法的时候,不能使用DEF文件。下面通过例子来说明使用导出函数关键字_declspec(dllexport)创建DLL文件:

该动态链接库中有两个函数,分别用来实现得到两个数的最大和最小数。在MyDll.h和MyDLL.cpp文件中分别输入如下原代码:

//MyDLL.h

extern "C" _declspec(dllexport) int desinit(int mode);

extern "C" _declspec(dllexport) void desdone(void);

extern "C" _declspec(dllexport) void des_setkey(char *subkey, char *key);

extern "C" _declspec(dllexport) void endes(char *block, char *subkey);

extern "C" _declspec(dllexport) void dedes(char *block, char *subkey);
//MyDll.cpp

#i nclude"MyDll.h"

//这里用比较大小的函数代替了我要实现的函数

int desinit(int a, int b)

{

if(a>=b)return a;

else

return b;

}

int desdone(int a, int b)

{

if(a>=b)return b;

else

return a;

}

该动态链接库编译成功后,打开MyDll工程中的debug目录,可以看到MyDll.dll、MyDll.lib两个文件。LIB文件中包含DLL文件名和DLL文件中的函数名等,该LIB文件只是对应该DLL文件的"映像文件",与DLL文件中,LIB文件的长度要小的多,在进行隐式链接DLL时要用到它。读者可能已经注意到在MyDll.h中有关键字"extern C",它可以使其他编程语言访问你编写的DLL中的函数。

2.LoadRunner调用动态链接库

完成动态链接库开发后,下面介绍动态链接库如何被LoadRunner调用。LoadRunner中的DLL调用有局部调用与全局调用:

局部调用方法:首先把编译的DLL放在脚本路径下,如MyDll.dll,MyDll.lib.然后在Action中使用lr_load_dll("MYDll.dll")将 DLL加载进来,进行使用即可如下:

#include "lrs.h"

Action()

{

//

int nRet = 6;

char srckey[129];

memset(srckey, ‘a‘, 128);

lr_message(lr_eval_string(srckey));

lr_load_dll("MyDLL.dll");

nRet = desinit(5,8);

lr_message("比较的结果为%d",nRet);

return 0;

}

运行结果

比较的结果为8

全局的动态链接库调用则需修改mdrv.dat,路径在LoadRunner的安装目录下面(LoadRunner/dat directory),在里面修改如下:

[WinSock]

*** name=wp32126>***ExtPriorityType=protocol

*** name=wp32127>***WINNT_EXT_LIBS=wsrun32.dll

*** name=wp32128>***WIN95_EXT_LIBS=wsrun32.dll

*** name=wp32129>***LINUX_EXT_LIBS=liblrs.so

*** name=wp32130>***SOLARIS_EXT_LIBS=liblrs.so

*** name=wp32131>***HPUX_EXT_LIBS=liblrs.sl

*** name=wp32132>***AIX_EXT_LIBS=liblrs.so

*** name=wp32133>***LibCfgFunc=winsock_exten_conf

*** name=wp32134>***UtilityExt=lrun_api

*** name=wp32135>***ExtMessageQueue=0

*** name=wp32136>***ExtCmdLineOverwrite=-WinInet No

*** name=wp18958>***ExtCmdLineConc=-UsingWinInet No

*** name=wp32140>***WINNT_DLLS=user_dll1.dll,user_dll2.dll, ...

//最后一行是加载你需要的DLL

这样你就可以在LR中随意的调用程序员写的API函数,进行一些复杂的数据加密,准备的一些操作,进行复杂的测试。同时如果你觉的有大量高复杂的运算也可以放在DLL中进行封装,以提高效率。

LoadRunner 调用dll方法

时间: 2024-08-11 01:35:48

LoadRunner 调用dll方法的相关文章

LoadRunner 调用Dll

LoadRunner(LR)里的函数真的少得相当可怜,连简单的一个MD5.Base64加密都没有. 但我们可以通过在C++里把一些加解密写成函数,供LR调用. DLL函数编写 C++里新建工程Class Library(本人是用VS2005,在VS6貌像是:Win32 Dynamic-Link Library) 创建了一个叫LrLoadDll的工程,在LrLoadDll.cpp里编写以下代码: #define LRLOADDLL __declspec(dllexport) extern "C&q

LoadRunner调用md5方法

LoadRunner调用md5方法 上一篇 / 下一篇  2011-04-29 11:25:12 / 个人分类:Loadrunner 查看( 958 ) / 评论( 0 ) / 评分( 0 / 0 ) 有个项目的请求参数中,有一个参数需要md5加密.在google搜索了些LR调用MD5方法的资料.参考资料实现了参数md5加密.现将方法做下总结: 1.首先将md5算法在C编译器中生成md5.h文件,在Vuser generator中添加这个md5.h文件,然后再global.h中添加#includ

LoadRunner 调用Dll完成加密解密

LoadRunner里的函数比较少,没有MD5.Base64加密. 我们可以通过在C++里把一些加解密写成函数,供LR调用. DLL函数编写 C++里新建工程Class Library(此处是用VS2005,在VS6是:Win32 Dynamic-Link Library) 创建了一个叫LrLoadDll的工程,在LrLoadDll.cpp里编写以下代码: #define LRLOADDLL __declspec(dllexport) extern"C" LRLOADDLL int S

QT 调用 DLL 方法(三种方法)

Qt调用DLL方法一:使用Win32 API 在显式链接下,应用程序必须进行函数 调用以在运行时显式加载 DLL.为显式链接到 DLL,应用程序必须:? 调用 LoadLibrary(或相似的函 数)以加载 DLL 和获取模块句柄.? 调用 GetProcAddress,以获 取指向应用程序要调用的每个导出函数的函数指针.由于应用程序是通过指针调用 DLL 的函数,编译器不生成外部引 用,故无需与导入库链接.? 使用完 DLL 后调用 FreeLibrary.例如:typedef UINT (C

QT创建与调用Dll方法(包括类成员)--显式调用

看网上的好多关于QT调用Dll的方法,大部分都是调用函数的,并没有调用C++类成员的情况,即使是有,比如说: 使用Qt编写模块化插件式应用程序 Qt 一步一步实现dll调用(附源码)---(这一篇里没有调用类成员的) Qt调用dll中的功能函数 ?我就是按照这上面的教程一步步做的,可惜了都没成功~~~这里面都有一个最重要的步骤没有说清楚(可能怪我笨~~),路径问题!!! 所以这里自我做一下总结: 创建时选择C++ Library就可以了,然后选择Shared Library(共享库),其他默认O

C# 通过反射类动态调用DLL方法

网上看了很多关于反射的思路和方法,发现这个还算不错 //使用反射方: using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Reflection; namespace ConsoleApplication1 { class Program { static void Main(string[] args) { //声明一个反射类对象 Assembly a

QT直接调用dll

Qt调用DLL方法 直接调用DLL则需要三个文件,头文件(.h).导入库文件(.lib).动态链接库(.dll),具体步骤如下: 注意:在qtCreaor中生成的动态库库文件文件为.a结尾,vs生成的动态链接库是.lib结尾 1.首先我们把 .h与.lib/.a 文件复制到程序当前目录下,然后再把dll文件复制到程序的输出目录(如果是debug版的话就将mydlld.dll放在此文件夹下,Release相同).(注意:如果dll是用C写的,因此要用 extern "C" { #incl

在C#调用C++的DLL方法(二)生成托管的DLL

写操作之前,还是扼要的说一下托管与非托管C++的区别好了,其实我也并没有深入了解过托管C++的特点所在,其最大的特征就是可以由系统来调试回收相关的代码资源,跟C#的特性一样,只是编程风格跟C++类似而已,因此,这决定了C#与托管C++是可以完美结合在一起的.托管C++生成的dll跟C#生成的dll应该说是没区别的,之所以产生托管C++这种怪物,完全是因为微软在极力推崇C#,必须要兼顾不同语言间交互. 好吧,接下来正经的写一下过程.先摆出目的:我手上有一个C++写的类(NativeClass),想

java中调用dll文件的两种方法

一中是用JNA方法,另外是用JNative方法,两种都是转载来的, JNA地址:http://blog.csdn.net/shendl/article/details/3589676   JNative地址:http://www.jb51.net/article/35232.htm JNA方法: 介绍 给大家介绍一个最新的访问本机代码的Java框架—JNA. JNA(Java Native Access)框架是一个开源的Java框架,是SUN公司主导开发的,建立在经典的JNI的基础之上的一个框架