反射式DLL注入--方法

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了反射式DLL注入--方法相关的知识,希望对你有一定的参考价值。

  1. 使用RWX权限打开目标进程,并为该DLL分配足够大的内存。
  2. 将DLL复制到分配的内存空间。
  3. 计算DLL中用于执行反射加载的导出的内存偏移量。
  4. 调用CreateRemoteThread(或类似的未公开的API函数RtlCreateUserThread)在远程进程中开始执行,使用反射加载函数的偏移地址作为入口点。
  5. 反射加载函数使用适当的CPU寄存器查找目标进程的进程环境块(PEB),并使用它查找内存中的地址kernel32.dll以及任何其他所需的库。
  6. 解析的KERNEL32出口目录中找到所需的API功能,如内存地址LoadLibraryAGetProcAddressVirtualAlloc
  7. 使用这些函数,然后正确加载DLL(本身)到内存中,并调用它的入口点,DllMain。

以上是关于反射式DLL注入--方法的主要内容,如果未能解决你的问题,请参考以下文章

反射机制依赖注入控制反转

网络安全红队攻防之基础免杀

逆向学习-DLL注入

常见的注入方法

常见的注入方法

Java利用Java的注解和反射实现一个"低配版"的依赖注入