效果展示:
添加断点-->F5
F10
1.创建CreateDllDemo(用来生成.dll)
Win32-->Win32项目-->CreateDllDemo-->确定-->下一步-->DLL-->完成
进入dllmain.cpp(四个调用原因)-->生成(3个文件,包括.dll)
// dllmain.cpp : 定义 DLL 应用程序的入口点。
#include "stdafx.h"
BOOL APIENTRY DllMain( HMODULE hModule, //模块句柄
DWORD ul_reason_for_call, //调用原因
LPVOID lpReserved
)
{
switch (ul_reason_for_call)
{
case DLL_PROCESS_ATTACH: //被其它程序加载
MessageBox(NULL, L"DLL被加载!PROCESS_ATTACH", L"I love Maek!", MB_OK);
break;
case DLL_THREAD_ATTACH: //当其它程序启动了一个线程的时候
MessageBox(NULL, L"DLL被线程加载!", L"I love Maek!", MB_OK);
break;
case DLL_THREAD_DETACH: //当其它程序某个线程终止运行的时候
MessageBox(NULL, L"DLL被线程卸载!", L"I love Maek!", MB_OK);
break;
case DLL_PROCESS_DETACH: //被其它程序卸载
MessageBox(NULL, L"DLL被卸载!PROCESS_DETACH", L"I love Maek!", MB_OK);
break;
}
return TRUE;
}
2.创建LoadDllDemo(用来调用.dll)
解决方案-->添加-->新建项目-->Win32控制台应用程序-->LoadDllDemo-->确定-->完成-->LoadDllDemo.cpp
#include <windows.h>
int main()
{
HMODULE hMoudule = ::LoadLibrary(L"DllExportDemo.dll");
//先找当前文件夹,如果没有,去System32中查找(重定向)64位 windows/system32;32位 windows/SysWOW64
//user32.dll,如果我在他的文本文件夹里面建立一个假的user32.dll,会先加载这个假的DLL(DLL劫持)
if (hMoudule == NULL)
{
MessageBox(NULL, L"加载DLL失败!",L"I Love Mark!", MB_OK);
}
return 0;
}
-->LoadDllDemo-->设为启动项目-->F5
3.创建DllExportDemo(动态链接库工程:DllMain函数、导出函数、内部函数)
解决方案-->添加-->新建项目-->Win32项目-->DllExportDemo-->确定-->下一步-->Dll-->导出符号-->完成
附:导出符号后,会比之前的多.h文件,且文件生成有.lib。
DllExportDemo.cpp
// DllExportDemo.cpp : 定义 DLL 应用程序的导出函数。
//
#include "stdafx.h"
#include "DllExportDemo.h"
// 这是导出变量的一个示例
DLLEXPORTDEMO_API int nDllExportDemo=0;
// 这是导出函数的一个示例。
//当前使用的是C++编译出来的,命名粉碎机制
//C++支持重载,将你所有的函数名称都粉碎
//故在.h文件中变成C形式
DLLEXPORTDEMO_API int fnDllExportDemo(void)
{
return 42;
}
// 这是已导出类的构造函数。
// 有关类定义的信息,请参阅 DllExportDemo.h
CDllExportDemo::CDllExportDemo()
{
return;
}
DllExportDemo.h
#ifdef DLLEXPORTDEMO_EXPORTS
#define DLLEXPORTDEMO_API __declspec(dllexport) //实现函数导出
#else
#define DLLEXPORTDEMO_API __declspec(dllimport)
#endif
// 此类是从 DllExportDemo.dll 导出的
class DLLEXPORTDEMO_API CDllExportDemo {
public:
CDllExportDemo(void);
// TODO: 在此添加您的方法。
};
extern DLLEXPORTDEMO_API int nDllExportDemo; //导出变量
//DLLEXPORTDEMO_API int fnDllExportDemo(void); //导出方法
extern "C" DLLEXPORTDEMO_API int fnDllExportDemo(void); //以C的方式编译
LoadDllDemo.cpp
// LoadDllDemo.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include <windows.h>
//静
#include "DllExportDemo.h"
#pragma comment(lib,"DllExportDemo.lib")
//动
//typedef int(*fnDllExportDemo)(void); //知原型,变指针,加类型
typedef int(*FUNC)(void); //这是一个函数类型
int main()
{
//动态
//可以调用.dll,但是麻烦
//HMODULE hMoudule = ::LoadLibrary(L"DllExportDemo.dll");
////先找当前文件夹,如果没有,去System32中查找(重定向)64位 windows/system32;32位 windows/SysWOW64
////user32.dll,如果我在他的文本文件夹里面建立一个假的user32.dll,会先加载这个假的DLL(DLL劫持)
//if (hMoudule == NULL)
//{
// MessageBox(NULL, L"加载DLL失败!",L"I Love Mark!", MB_OK);
//}
//FUNC dllFunc = (FUNC)::GetProcAddress(hMoudule, "fnDllExportDemo"); //用于传递,句柄放入,返回指针
//printf("%d", dllFunc());
//静态-->复制头文件,到工程文件下-->复制.lib库,放到使用的文件夹下(同一文件夹)
printf("%d", fnDllExportDemo());
return 0;
}