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 命令可以看到最上面是一个 int 3 中断,截图如下: - |( |# m d3 p' M$ z- o, }5 V: ^
! W$ \; W. s* c5 L: N; \" @3 \8 M5 V
这里就有一个想法了,既然 WinDbg 可以注入,为何我的程序就注入不得呢?既然我的程序可以注入,那就可以做一些我想做的事情。 ' v, e; c/ d; f* ` g5 J8 ` ^3. 自定义注入 , W r a& `# i1 F/ B 有了自定义注入的想法,接下来的实现步骤大概是这样的。* Z! A. I6 x: O% A6 O: y8 |+ Q
注入一个线程到 C# 程序中。
让程序加载一个 dll 文件。
在 dll 中做一些我想做的业务逻辑。 : m: A; ?% z9 p* \3 x
接下来新建一个 C++ 的动态链接库,在 DLLMain 入口函数的 DLL_PROCESS_ATTACH 事件中写一个 printf 函数,如果在 C# 程序中输出来了,就算成功注入了,参考代码如下:* i: B$ y+ l: x/ k4 ^% W