DLL注入技术之依赖可信进程注入

DLL注入技术之依赖可信进程注入

    依赖可信进程注入原理是利用Windows 系统中Services.exe这个权限较高的进程,首先将a.dll远线程注入到Services.exe中,再利用a.dll将b.dll远线程注入到待注入进程中。具体过程如下图所示:


这里提供一个小技巧,当注入到Services.exe里的DLL时,想在做完事情后悄无声息的将自己释放掉,在Windows 中有这样的一个API函数FreeLibraryAndExitThread(),它可以把自己卸载掉并且退出线程,具体代码如下:

  1. DWORD ThreadProc(CMfcServicesInjectDLLApp* pThis)  
  2. {     
  3.     //切换mfc模块  
  4.     AFX_MANAGE_STATE(AfxGetStaticModuleState());  
  5.     pThis->m_InjectObj.Attach(  
  6.         _T("calc.exe"),  
  7.         _T("D:\\MyDll\\RelyServicesInject\\Debug\\MfcExeInjectDLL.dll"));  
  8.     //在线程中卸载掉自己并且退出线程  
  9.     FreeLibraryAndExitThread(pThis->m_hInstance,0);  
  10.     return 0;  
  11. }  
  12.   
  13. // CMfcServicesInjectDLLApp 初始化  
  14. BOOL CMfcServicesInjectDLLApp::InitInstance()  
  15. {  
  16.     DWORD dwThreadId;  
  17.     m_hThread = ::CreateThread(NULL, NULL,   
  18.         (LPTHREAD_START_ROUTINE)ThreadProc,   
  19.         this, NULL,&dwThreadId);  
  20.         return TRUE;  
  21. }  

依赖可信进程注入其实就是远线程注入的增强版,它利用了系统较高权限的进程进行远程注入,大大提高了注入的成功率,并在注入完毕后释放掉自己,降低了被查杀的可能性。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值