Dll重定向(尚存否?)
windows核心编程(第五版)的20.6节介绍了Dll重定向。
0x01 Dll重定向简介
产生Dll重定向原因:
应用程序 a.exe 依赖动态链接库 compoent.dll 1.0 版本。但是用户的另一个软件 b 在系统的系统目录安装了 component.dll 2.0 版本,这两个版本不兼容,
因此,Windows 在加载 component.dll 的时候,会直接加载系统目录中的 component.dll,这就造成了 a.exe 程序无法运行,如果这时用户需要同时使用两个软件,就会造成所谓的 DLL Hell。
动态链接库重定向技术如何解决 DLL Hell:
这里有两种方法可以作为解决方案:
1.创建 a.exe.local 文件,该文件内容为空。
这时系统就会强制使 a.exe LoadLibrary 时先在 a.exe 所在的目录下查找要加载的动态库,之后才到系统目录下寻找。这个解决方法适用于两个不同的应用。
2.创建 a.exe.local 目录,将 a.exe 依赖的库放入其中。
这时系统就会强制使 a.exe LoadLibrary 时先在 a.exe.local 目录下查找要加载的动态库,之后才到系统目录下寻找。这个解决方法适用于单个应用中存在两个应用程序,并且以来同名但是互不兼容的库。
动态链接库重定向技术实际上是 M$ 修改了 LoadLibrary(Ex) 的代码,使其在调用时先检测是否存在 <AppName>.local 文件或目录实现重定向的。它是作为临时解决 DLL HELL 的方法。并且,当应用程序存在 Manifest 时,该技术将不会起作用。
0x01 Dll重定向实现步骤:
(假设我的EXE为SHApp.exe, 要调试的DLL为 SHModule.dll):
1) 在 SHApp.exe 的目录下创建一个 SHApp.exe.local
2) 把你希望加载的 SHModule.dll 复制到 SHApp.exe.local 目录下
3) 运行 SHApp.exe
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 | #include "stdafx.h" #include <Windows.h> #include <stdio.h> int main() { CHAR szMoudlePath[MAX_PATH]; LPSTR szKernel32 = "kernel32.dll" ; LPSTR szuser32 = "user32.dll" ; HMODULE hKernel32; //使用NULL参数,获取本模块路径 if (!GetModuleFileNameA(NULL, szMoudlePath, MAX_PATH)) { return 0;} printf ( "本模块路径 %s \n\n" , szMoudlePath); hKernel32 = LoadLibraryA(szKernel32); //使用Kernel32.dll的句柄模块,获取其路径 if (!GetModuleFileNameA(hKernel32, szMoudlePath, MAX_PATH)) { return 0;} printf ( "kernel32模块路径 %s \n" , szMoudlePath); return 0; } |
按照这位博主的说法(http://blog.csdn.net/zacklin/article/details/7535569),要打开.local这个功能,需要在注册表设置DevOverrideEnable值,并且重启机器
[HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Windows NT/CurrentVersion/Image File Execution Options]
"DevOverrideEnable"=dword:00000001
然而,在笔者win10的注册表上,并没有找到这个键值:
所以笔者猜测win10下的此技术可能得到了改进?又或者是我个人的原因?各位看官路过如若知晓的话,还望不吝赐教,感激不尽~
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
· AI Agent开发,如何调用三方的API Function,是通过提示词来发起调用的吗