DLL劫持
2021/7/18 23:12:22
本文主要是介绍DLL劫持,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
可执行文件运行时会经历以下步骤:
第一步:Windows加载器会将PE(Portable Executable File Format)文件映射到内存中
第二步:分析可执行文件的导入表,寻找执行文件所需要的DLL文件(因为导入表中只有DLL文件的名称,没有路径信息,因此有了第三步)
第三步:按照第二步提供的DLL文件名称,Windows加载器在磁盘上搜索DLL文件,当前程序所在的目录(不会搜索父目录和子目录)->Windows系统目录->环境变量(按照这个顺序依次寻找DLL文件,一旦找到就停止寻找)
第四步:将相应的DLL文件装入,找到DLL中相应的函数,从而运行相应的函数。
DLL劫持原理:因为DLL搜索顺序原理,可以伪造一个DLL文件存放到程序所在目录,该伪造的DLL文件主要实现两个作用:1.实现恶意功能 2.调用真实的DLL文件。
所以会发现,可执行文件运行的时候会调用两个一样名称的DLL文件,一个是我们伪造的,一个是真实的,真实的DLL是由伪造的DLL去调用的。这样,在可执行文件运行时,既实现了恶意功能,又因为调用了真实的DLL,所以并不会导致可执行文件运行不了,这就是DLL劫持。
什么样的DLL不可以劫持?
注册表位置:\HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager\KnownDLLs,在此项下的DLL会被禁止从EXE自身所在目录下调用,而只能从系统目录即SYSTEM32目录下调用。
此注册表下的DLL不可以被劫持,因为搜索到程序所在目录下的DLL文件时是被禁止调用的,所以只能继续搜索Windows系统目录下的DLL文件。不可能把伪造的DLL文件放在Windows系统目录下,因为真实的DLL文件在Windows系统目录下,因为两个文件是同名称的,如果要把伪造的DLL文件放在Windows系统目录下只能删除真实的DLL,那就会导致可执行文件运行不了。
什么样的DLL可以劫持?
可以通过Proccess,查看运行该可执行文件需要的DLL文件,除去上述注册表中的DLL文件,剩下的都可以劫持。
具体流程可参考:https://blog.csdn.net/weixin_39523280/article/details/111214502
这篇关于DLL劫持的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-04百万架构师第六课:设计模式:策略模式及模板模式
- 2025-01-04百万架构师第七课:设计模式:装饰器模式及观察者模式
- 2025-01-04适用于企业管理的协作工具API推荐
- 2025-01-04挑战16:被限流的CPU
- 2025-01-03企业在选择工具时,如何评估其背后的技术团队
- 2025-01-03Angular中打造动态多彩标签组件的方法
- 2025-01-03Flask过时了吗?FastAPI才是未来?
- 2025-01-0311个每位开发者都应知道的免费实用网站
- 2025-01-03从REST到GraphQL:为什么以及我是如何完成转型的
- 2025-01-03掌握RAG:从单次问答到连续对话