[Windows编程] 通过GetModuleHandleEx 得到函数调用者所在的DLL/EXE 原创陈本峰2009-02

简介:
在有些情况下需要得到函数调用者的模块名字。比如你想限制你的某个函数只能被自己某个特定的DLL调用。 或者比如在异常处理中你想了解是那个DLL/EXE抛出了异常。
API函数_ReturnAddress 和GetModuleHandleEx 函数可以帮助我们达到这个目的。以下代码演示它们的用法:
 view plaincopy to clipboardprint?
void ShowCallerModuleName()   
{   
    HMODULE hCallerModule = NULL;   
    TCHAR szModuleName[MAX_PATH] = _T("");   
    void *callerAddress = _ReturnAddress();   
    if (GetModuleHandleEx(GET_MODULE_HANDLE_EX_FLAG_FROM_ADDRESS, (LPCTSTR)callerAddress, &hCallerModule))   
    {   
        GetModuleFileName(hCallerModule, szModuleName, ARRAYSIZE(szModuleName));   
        MessageBox(NULL, szModuleName, _T("Who is calling me?"), MB_OK);   
    }   
}  
void ShowCallerModuleName()
{
 HMODULE hCallerModule = NULL;
    TCHAR szModuleName[MAX_PATH] = _T("");
 void *callerAddress = _ReturnAddress();
    if (GetModuleHandleEx(GET_MODULE_HANDLE_EX_FLAG_FROM_ADDRESS, (LPCTSTR)callerAddress, &hCallerModule))
 {
  GetModuleFileName(hCallerModule, szModuleName, ARRAYSIZE(szModuleName));
  MessageBox(NULL, szModuleName, _T("Who is calling me?"), MB_OK);
 }
}
解释:
_ReturnAddress 可以给你所在函数的返回地址,也就是调用者的地址。
GetModuleHandleEx 可以给你某个地址所在的模块Handle 。 得到这个Handle 之后,就可以用GetModuleFileName 来得到模块的文件名了。
如上面提到的,我们可以用这个方法来捕捉是哪个DLL/EXE抛出异常。 在程序入口加入
view plaincopy to clipboardprint?
SetUnhandledExceptionFilter(ShowCallerModuleName)


在有些情况下需要得到函数调用者的模块名字。比如你想限制你的某个函数只能被自己某个特定的DLL调用。 或者比如在异常处理中你想了解是那个DLL/EXE抛出了异常。
API函数_ReturnAddress 和GetModuleHandleEx 函数可以帮助我们达到这个目的。以下代码演示它们的用法:
 view plaincopy to clipboardprint?
void ShowCallerModuleName()   
{   
    HMODULE hCallerModule = NULL;   
    TCHAR szModuleName[MAX_PATH] = _T("");   
    void *callerAddress = _ReturnAddress();   
    if (GetModuleHandleEx(GET_MODULE_HANDLE_EX_FLAG_FROM_ADDRESS, (LPCTSTR)callerAddress, &hCallerModule))   
    {   
        GetModuleFileName(hCallerModule, szModuleName, ARRAYSIZE(szModuleName));   
        MessageBox(NULL, szModuleName, _T("Who is calling me?"), MB_OK);   
    }   
}  
void ShowCallerModuleName()
{
 HMODULE hCallerModule = NULL;
    TCHAR szModuleName[MAX_PATH] = _T("");
 void *callerAddress = _ReturnAddress();
    if (GetModuleHandleEx(GET_MODULE_HANDLE_EX_FLAG_FROM_ADDRESS, (LPCTSTR)callerAddress, &hCallerModule))
 {
  GetModuleFileName(hCallerModule, szModuleName, ARRAYSIZE(szModuleName));
  MessageBox(NULL, szModuleName, _T("Who is calling me?"), MB_OK);
 }
}
解释:
_ReturnAddress 可以给你所在函数的返回地址,也就是调用者的地址。
GetModuleHandleEx 可以给你某个地址所在的模块Handle 。 得到这个Handle 之后,就可以用GetModuleFileName 来得到模块的文件名了。
如上面提到的,我们可以用这个方法来捕捉是哪个DLL/EXE抛出异常。 在程序入口加入
view plaincopy to clipboardprint?
SetUnhandledExceptionFilter(ShowCallerModuleName)




 本文转自 陈本峰 51CTO博客,原文链接:http://blog.51cto.com/wingeek/273935,如需转载请自行联系原作者

相关文章
|
3月前
|
存储 Java C语言
Windows 下 JNI 调用动态链接库 dll
Windows 下 JNI 调用动态链接库 dll
59 0
|
5月前
|
消息中间件 C++ Windows
02 MFC - Windows 编程模型
02 MFC - Windows 编程模型
22 0
|
3月前
|
存储 Java C++
Windows 下 JNA 调用动态链接库 dll
Windows 下 JNA 调用动态链接库 dll
41 0
|
2月前
|
Windows
火山中文编程 -- 第一个windows程序
火山中文编程 -- 第一个windows程序
12 0
|
2月前
|
编译器 API Windows
windows编程基础
windows编程基础
13 0
|
2月前
|
Windows
win32编程 -- windows绘图操作
win32编程 -- windows绘图操作
20 0
|
3月前
|
网络协议 Linux C语言
005.在Windows下编程让效率起飞
windows开发Linux方式: 先用编辑器编写源代码 然后进入Linux 系统,使用gcc编译器(后面会讲),对源代码进行编译运行。 熟练后推荐使用VS2019 开发Linux C++ 程序 将自己的Ip地址设为静态IP
40 1
|
4月前
|
XML Arthas Java
Windows【工具 04】WinSW官网使用说明及实例分享(将exe和jar注册成服务)实现服务器重启后的服务自动重启
Windows【工具 04】WinSW官网使用说明及实例分享(将exe和jar注册成服务)实现服务器重启后的服务自动重启
106 0
|
4月前
|
人工智能 机器人 C#
Windows编程课设(C#)——基于WPF和.net的即时通讯系统(仿微信)
一款参考QQ、微信的即时通讯软件。采用CS结构,客户端基于.Net与WPF开发,服务端使用Java开发。
|
4月前
|
网络协议 安全 API
9.9 Windows驱动开发:内核远程线程实现DLL注入
在笔者上一篇文章`《内核RIP劫持实现DLL注入》`介绍了通过劫持RIP指针控制程序执行流实现插入DLL的目的,本章将继续探索全新的注入方式,通过`NtCreateThreadEx`这个内核函数实现注入DLL的目的,需要注意的是该函数在微软系统中未被导出使用时需要首先得到该函数的入口地址,`NtCreateThreadEx`函数最终会调用`ZwCreateThread`,本章在寻找函数的方式上有所不同,前一章通过内存定位的方法得到所需地址,本章则是通过解析导出表实现。
67 0
9.9 Windows驱动开发:内核远程线程实现DLL注入