




下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第在C#程序中注入恶意DLL的方法详解目录一、背景二、实现原理1.基本思路2.案例演示3.自定义注入三:总结
一、背景
前段时间在训练营上课的时候就有朋友提到一个问题,为什么Windbg附加到C#程序后,程序就处于中断状态了?它到底是如何实现的?其实简而言之就是线程的远程注入,这一篇就展开说一下。
二、实现原理
1.基本思路
WinDbg在附加进程的时候,会注入一个线程到C#进程中,注入成功后,会执行一个DbgBreakPoint()函数,其实就是int3,这时候CPU就会执行3号中断函数,将当前进程的所有线程进行暂停,文字不好理解的话,画一个图大概就是这样。
口说无凭,接下来用上一个简单案例演示一下。
2.案例演示
首先写一个简单的C#程序,不断的输出时间和标号,代码如下:
internal
class
Program
{
static
void
Main(string[]
args)
{
for
(int
i
=
0;
i
10000;
i++)
{
Console.WriteLine($"{DateTime.Now},i={i}");
Thread.Sleep(1000);
}
}
}
把程序跑起来后,使用WinDbg附加,你可以发现Command自动切换到了8号线程,通过k命令可以看到最上面是一个int3中断,截图如下:
这里就有一个想法了,既然WinDbg可以注入,为何我的程序就注入不得呢?既然我的程序可以注入,那就可以做一些我想做的事情。
3.自定义注入
有了自定义注入的想法,接下来的实现步骤大概是这样的。
注入一个线程到C#程序中。让程序加载一个dll文件。在dll中做一些我想做的业务逻辑。
接下来新建一个C++的动态链接库,在DLLMain入口函数的DLL_PROCESS_ATTACH事件中写一个printf函数,如果在C#程序中输出来了,就算成功注入了,参考代码如下:
#include
Windows.h
#include
stdio.h
BOOL
APIENTRY
DllMain(HMODULE
hModule,
DWORD
ul_reason_for_call,
LPVOID
lpReserved
switch
(ul_reason_for_call)
case
DLL_PROCESS_ATTACH:
printf("
总部,总部,我已经成功打入内部!ul_reason_for_call=%d\n",
ul_reason_for_call);
break;
return
TRUE;
要被加载的MyInject.dll已经构建完毕,接下来就用Win32API的CreateRemoteThread()实现远程注入,但注入之前需要做三件事情。
获取C#程序的进程句柄。在C#进程中申请一块内存空间,存放加载的path路径。调用LoadLibraryW函数在C#进程中实现dll加载。
过程有了,新建一个C++控制台程序ConsoleApplication1.exe,整体的参考代码如下:
#include
iostream
#include
Windows.h
#include
stdio.h
#include
stdlib.h
#include
Tlhelp32.h
DWORD
GetPid(const
WCHAR*
szName)
HANDLE
hprocessSnap
=
NULL;
PROCESSENTRY32
pe32
=
{
0
};
hprocessSnap
=
CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS,
0);
pe32.dwSize
=
sizeof(PROCESSENTRY32);
if
(Process32First(hprocessSnap,
pe32))
do
{
if
(!wcscmp(szName,
pe32.szExeFile))
{
return
(int)pe32.th32ProcessID;
}
while
(Process32Next(hprocessSnap,
pe32));
else
CloseHandle(hprocessSnap);
return
0;
int
main()
const
wchar_t*
path
=
L"D:\\net6\\ConsoleApp1\\x64\\Debug\\MyInject.dll";
//要注入的dll文件地址
//1.
获取进程ID
DWORD
procID
=
GetPid(L"ConsoleApp4.exe");
//2.
获取进程句柄
HANDLE
hProcess
=
OpenProcess(PROCESS_ALL_ACCESS,
FALSE,
procID);
//3.
在目标进程中开辟一块空间
LPVOID
pRemoteAdress
=
VirtualAllocEx(hProcess,
NULL,
wcslen(path)
*
2,
MEM_COMMIT,
PAGE_READWRITE);
//4.
将
path
写入到这块空间中
BOOL
bRet
=
WriteProcessMemory(hProcess,
pRemoteAdress,
path,
wcslen(path)
*
2,
NULL);
//5.
让目标线程调用
LoadLibraryW
加载我们注入的
dll
HMODULE
hModule
=
GetModuleHandle(L"kernel32.dll");
LPTHREAD_START_ROUTINE
dwLoadAddr
=
(LPTHREAD_START_ROUTINE)GetProcAddress(hModule,
"LoadLibraryW");
HANDLE
hThread
=
CreateRemoteThread(
hProcess,
NULL,
(LPTHREAD_START_ROUTINE)dwLoadAddr,
pRemoteAdress,
NULL,
NULL
//6.函数执行完后,释放这块空间。
WaitForSingleObject(hThread,
-1);
VirtualFreeEx(hProcess,
pRemoteAdress,
1,
MEM_DECOMMIT);
system("pause");
return
0;
}
万事具备,接下来我们将ConsoleApplication1.exe启动,可以成功观察到ConsoleApp4.exe上已经注入成功的输出,截图如下:
三:总结
这就是对Win
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025至2030中国无损评估(NDE)行业现状调查与前景策略研究报告
- 2025至2030中国康复辅助器具市场供需预测与投资盈利性调研报告
- 2025至2030中国巴西棕榈蜡市场产能规模及未来经营效益研究报告
- 2025至2030中国太阳能驱动水泵控制器行业运营格局与投资动态研究报告
- 2025至2030中国复合肥料行业供需态势及盈利趋势研究报告
- 2025至2030中国合成有机染料行业竞争状况及投资前景研究报告
- 2025至2030中国发泡聚丙烯行业需求趋势及投资方向研究报告
- 2025至2030中国卵孵化器市场运营模式与投资趋势前景研究报告
- 网络界限的安全性与试题及答案
- 交通运输行业人才需求变化趋势与培养体系优化研究报告
- 高中英语课程标准新课标英文版
- 心理危机干预培训课件
- 2023年心血管内科学考博真题
- 保温杯生产工艺流程
- GB/T 6482-2007凿岩用螺纹连接钎杆
- 理正深基坑算例
- 公司休假销假单模板
- 《基于杜邦分析法的企业财务分析国内外文献综述》
- 全国高中数学联赛广东省预赛试题及解答
- DB33T 2226-2019 空气负(氧)离子观测与评价技术规范-纯图
- 高中政治教学的经验分享课件
评论
0/150
提交评论