• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Delphi进程防杀

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

用过卡巴斯基的朋友都知道,卡巴斯基的进程是无法杀掉的,在任务管理器中杀卡巴进程的话,会弹出一个消息框提示拒绝访问!那么这是怎么实现的呢?很简单,就是使用了HOOK API的方法。

我用delphi来写程序好了,先写个dll。

 

const 
PRG_NAME = 'ddos.exe';

var TerminateProcessNext : function (processHandle, exitCode: dword) : bool; stdcall; 
NtTerminateProcessNext : function (processHandle, exitCode: dword) : dword; stdcall; 


{$R *.res}
function ThisIsOurProcess(processHandle: dword) : boolean; 
var pid : dword; 
arrCh : array [0..MAX_PATH] of char; 
begin 
pid := ProcessHandleToId(processHandle); 
result := (pid <> 0) and ProcessIdToFileName(pid, arrCh) and 
(PosText(PRG_NAME, arrCh) > 0); 
end; 

function TerminateProcessCallback(processHandle, exitCode: dword) : bool; stdcall; 
begin 
if ThisIsOurProcess(processHandle) then 
begin 
result := false; 
SetLastError(ERROR_ACCESS_DENIED); 
end 
else 
result := TerminateProcessNext(processHandle, exitCode); 

end; 

function NtTerminateProcessCallback(processHandle, exitCode: dword) : dword; stdcall; 
const STATUS_ACCESS_DENIED = $C0000022; 
begin 
if ThisIsOurProcess(processHandle) then 
begin 
result := STATUS_ACCESS_DENIED 
end 
else 
result := NtTerminateProcessNext(processHandle, exitCode); 
end; 

begin
if GetVersion and $80000000 = 0 then 
HookAPI( 'ntdll.dll', 'NtTerminateProcess', @NtTerminateProcessCallback, @NtTerminateProcessNext) 
else HookAPI('kernel32.dll', 'TerminateProcess', @TerminateProcessCallback, @TerminateProcessNext); 
end.

 

再写个exe调用这个dll,把这个dll插入到系统进程中去。

 

procedure inject; 
begin 
try 
if not InjectLibrary((CURRENT_SESSION or CURRENT_PROCESS), 'hook.dll') then 
begin
ExitProcess(0); //如果没有把hook.dll插入到进程中去,那么程序就自动关闭
end; 
except 
// 
end; 
end;


procedure uninject; //把hook.dll从插入的进程中卸载掉
begin 
try 
UninjectLibrary((CURRENT_SESSION or CURRENT_PROCESS), 'hook.dll');
except 
end; 
end; 


procedure TForm1.FormCreate(Sender: TObject);
begin
inject; //程序一启动就插入dll
end;

procedure TForm1.FormDestroy(Sender: TObject);
begin
uninject; //程序退出把dll从进程中卸载,保护进程功能也就失效了。
end;

鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
一个Delphi写的DES算法, 翻译成C#发布时间:2022-07-18
下一篇:
delphi通过TADOConnection组件直接连接MSSQL数据库并读写数据。发布时间:2022-07-18
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap