远程爆破,另类结束进程的方式(插入线程式)

老套结束进程方式是OpenProcess,然后TerminateProcess。但是遇到那些Hook过TerminateProcess的程序,以及内核模式的程序(比如很多杀毒软件),这招就无能为力了。TerminateProcess的最终结果是没有任何变化或者你的程序直接死掉...

 

老早就想过用其他方式来结束进程了,比如让自己也工作在内核模式...这里给出一种很简单的办法,远程爆破目标程序。说白了,就是插入一个线程到目标程序,执行一段崩溃代码,让目标从内部自己死掉。就好像扔一个炸弹道目标内部,所以叫远程爆破。

 

 

实现原理:

1.首先是怎么让目标程序崩溃。平时有遇到程序崩溃吧,还记得那段代码怎么写吗?(谁去记这种会死机的代码啊)不知道怎么写,那告诉你一个最简单的方式吧,CreateRemoteThread的开始地址,直接用0代替,自己试试读写0处的物理内存吧,是不是直接"0x00000000" 指令引用的 "0x00000000" 内存。该内存不能为 "read"。,出现这个就达到目的了。但是保险起见,还是自行写一段必然会引起崩溃的代码好些,毕竟这样稳妥些。

  其实不用那么暴力,也能让目标程序结束掉的。还记得ExitProcess()吗?就是那个只能用在自己程序里的退出API,注射 $7C81CAA2 这个的地址就好了(具体怎么获得见后面)。这样就好比扔把刀子给别人,让他去自杀...汗

 

2.注射线程的例子就很多了,这里略过。主要要注意,对于那些内核模式的进程,不在同级下运行是不能CreateRemoteThread的。而且最好是提升到Debug权限,不然别想远程注射。

 

 

 

程序实现: (全部代码在2楼)

1.EnabledDebugPrivilege(True);  //提升到Debug权限。抄Delphi下深入Windows核心编程里的

 

2.然后弄到进程ID,放到sc_pID里

hRemoteProcess := OpenProcess(PROCESS_CREATE_THREAD + {允许远程创建线程}

      PROCESS_VM_OPERATION + PROCESS_VM_WRITE,          {允许远程VM操作 + 允许远程VM写}

      FALSE, sc_pID);

 

3.获取ExitProcess的地址:(XP下是 $7C81CAA2 )

pfnStartAddr := GetProcAddress(GetModuleHandle('kernel32'), 'ExitProcess');

 

4.老方法,从 $7C81CAA2 处远程线程

hThread:=CreateRemoteThread(hRemoteProcess, nil, 0, pfnStartAddr, nil, 0, TempVar);

这里也能直接把第三四步和到一块,更简洁。第二个nil是指ExitProcess的参数,反正我们要调用ExitProcess(0),所以传nil了。

 

好了,执行看看,该死的QQ不声不响的关掉了,Word也是,但是lsass.exe不行,ExitProcess根本就没响应。既然这样,就直接爆破吧。

 

5.修改CreateRemoteThread

hThread:=CreateRemoteThread(hRemoteProcess, nil, 0, Pointer($0), Pointer($10000), 0, TempVar);

目标lsass.exe!然后lsass.exe - 应用程序错误

"0x00000000" 指令引用的 "0x00000000" 内存。该内存不能为 "read"。然后OpenProcess失效,因为lsass已经被干掉了。

 

但是要注意了,像smss.exe这种内核模式的进程,直接用CreateRemoteThread是新建不了线程的。要想hThread不是0,先让你的程序也运行在内核模式吧。

为看看效果,于是顺手把winlogin.exe spoolsv.exe services.exe也爆破掉了。然后是久违的蓝屏...

注意:千万别去动系统进程,这是我十几次重启换来的血的教训!

 

Pointer($0)这招,当然也有失效的时候,csrss.exe就能读0地址,不会直接死掉。所以尽量自己实现崩溃代码,让Windows告诉我们XXX 遇到问题需要关闭。我们对此引起的不便表示抱歉。吧!其他常见的方法,还有用VirtualAllocEx开一块超大空间,WriteProcessMemory在目标程序里乱写等,不过前提是你的权限足够大。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值