青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

tommy

It's hard to tell the world we live in is either a reality or a dream
posts - 52, comments - 17, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

Hook SSDT

Posted on 2009-03-21 16:19 Tommy Liang 閱讀(1270) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 進(jìn)程與線程
看了《Rootkit》和《黑客防線2009》的文章,代碼寫了一下,有些體會(huì):

驅(qū)動(dòng)程序代碼:
#include "ntddk.h"
#define NT_DEVICE_NAME L"\\Device\\ProtectProcess"
#define DOS_DEVICE_NAME L"\\DosDevices\\ProtectProcess"
#define IOCTL_PROTECT_CONTROL CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS)

NTSTATUS DispatchDeviceControl(IN PDEVICE_OBJECT DeviceObject,IN PIRP Irp);
void OnUnload(IN PDRIVER_OBJECT DriverObject);

#pragma pack(
1)
typedef 
struct ServiceDescriptorEntry{
    unsigned 
int *ServiceTableBase;
    unsigned 
int *ServiceCounterTableBase;
    unsigned 
int NumberOfServices;
    unsigned 
char *ParamTableBase;
}
 SSDT_Entry,*pSSDT_Entry;
#pragma pack()
__declspec(dllimport) SSDT_Entry KeServiceDescriptorTable;

#define SYSTEMSERVICE(_func) \
    KeServiceDescriptorTable.ServiceTableBase[
*(PULONG)((PUCHAR)_func+1)]

NTSYSAPI NTSTATUS NTAPI ZwOpenProcess(OUT PHANDLE ProcessHandle,
    IN ACCESS_MASK DesiredAccess,
    IN POBJECT_ATTRIBUTES ObjectAttributes,
    IN PCLIENT_ID ClientId OPTIONAL);

typedef NTSTATUS (
*ZWOPENPROCESS)(OUT PHANDLE ProcessHandle,
    IN ACCESS_MASK DesiredAccess,
    IN POBJECT_ATTRIBUTES ObjectAttributes,
    IN PCLIENT_ID ClientId OPTIONAL);

ZWOPENPROCESS OldZwOpenProcess;
long pid = 0;

NTSTATUS NewZwOpenProcess(OUT PHANDLE ProcessHandle,
    IN ACCESS_MASK DesiredAccess,
    IN POBJECT_ATTRIBUTES ObjectAttributes,
    IN PCLIENT_ID ClientId OPTIONAL)
{
    NTSTATUS nStatus 
= STATUS_SUCCESS;
    
if((long)ClientId->UniqueProcess == pid)
    
{
        DbgPrint(
"保護(hù)進(jìn)程 PID:%d\n",pid);
        
return STATUS_ACCESS_DENIED;
    }

    nStatus 
= OldZwOpenProcess(ProcessHandle,DesiredAccess,ObjectAttributes,ClientId);
    
return nStatus;
}


void OnUnload(IN PDRIVER_OBJECT DriverObject)
{
    UNICODE_STRING DeviceLinkString;
    PDEVICE_OBJECT DeviceObjectTemp1 
= NULL;
    PDEVICE_OBJECT DeviceObjectTemp2 
= NULL;
    DbgPrint(
"驅(qū)動(dòng)程序卸載\n");
    RtlInitUnicodeString(
&DeviceLinkString,DOS_DEVICE_NAME);
    IoDeleteSymbolicLink(
&DeviceLinkString);
    
if(DriverObject)
    
{
        DeviceObjectTemp1 
= DriverObject->DeviceObject;
        
while(DeviceObjectTemp1)
        
{
            DeviceObjectTemp2 
= DeviceObjectTemp1;
            DeviceObjectTemp1 
= DeviceObjectTemp1->NextDevice;
            IoDeleteDevice(DeviceObjectTemp2);
        }

    }

    DbgPrint(
"設(shè)備已卸載\n");
    DbgPrint(
"修復(fù)SSDT\n");
    (ZWOPENPROCESS)(SYSTEMSERVICE(ZwOpenProcess)) 
= OldZwOpenProcess;
    DbgPrint(
"驅(qū)動(dòng)卸載完畢\n");
}


NTSTATUS DispatchDeviceControl(IN PDEVICE_OBJECT DeviceObject, IN PIRP Irp)
{
    NTSTATUS nStatus 
= STATUS_SUCCESS;
    ULONG IoControlCode 
= 0;
    PIO_STACK_LOCATION IrpStack 
= NULL;
    
long* inBuf = NULL;
    
char* outBuf = NULL;
    ULONG inSize 
= 0;
    ULONG outSize 
= 0;
    PCHAR buffer 
= NULL;
    PMDL mdl 
= NULL;

    Irp
->IoStatus.Status = STATUS_SUCCESS;
    Irp
->IoStatus.Information = 0;
    IrpStack 
= IoGetCurrentIrpStackLocation(Irp);

    
switch(IrpStack->MajorFunction)
    
{
        
case IRP_MJ_CREATE:
            DbgPrint(
"IRP_MJ_CREATE 被調(diào)用\n");
            
break;
        
case IRP_MJ_CLOSE:
            DbgPrint(
"IRP_MJ_CLOSE 被調(diào)用\n");
            
break;
        
case IRP_MJ_DEVICE_CONTROL:
            DbgPrint(
"IRP_MJ_DEVICE_CONTROL 被調(diào)用\n");
            IoControlCode 
= IrpStack->Parameters.DeviceIoControl.IoControlCode;
            
switch(IoControlCode)
            
{
                
case IOCTL_PROTECT_CONTROL:
                    inSize 
= IrpStack->Parameters.DeviceIoControl.InputBufferLength;
                    outSize 
= IrpStack->Parameters.DeviceIoControl.OutputBufferLength;
                    inBuf 
= (long*)Irp->AssociatedIrp.SystemBuffer;
                    pid 
= *inBuf;
                    DbgPrint(
"=========================================\n");
                    DbgPrint(
"IOCTRL_PROTECT_CONTROL 被調(diào)用,通訊成功!\n");
                    DbgPrint(
"輸入緩沖區(qū)大?。?d\n",inSize);
                    DbgPrint(
"輸出緩沖區(qū)大?。?d\n",outSize);
                    DbgPrint(
"輸入緩沖區(qū)內(nèi)容:%ld\n",*inBuf);
                    DbgPrint(
"當(dāng)前保護(hù)進(jìn)程ID:%ld\n",pid);
                    DbgPrint(
"=========================================\n");
                    
                    strcpy(Irp
->UserBuffer,"OK\n");
                    
break;
                
default:
                    
break;
            }

            
break;
        
default:
            DbgPrint(
"未知請(qǐng)求包被調(diào)用\n");
            
break;
    }

    nStatus 
= Irp->IoStatus.Status;
    IoCompleteRequest(Irp,IO_NO_INCREMENT);
    
return nStatus;
}


NTSTATUS DriverEntry(IN PDRIVER_OBJECT DriverObject,IN PUNICODE_STRING theRegistryPath)
{
    NTSTATUS ntStatus 
= STATUS_SUCCESS;
    UNICODE_STRING ntDeviceName;
    UNICODE_STRING DeviceLinkString;
    PDEVICE_OBJECT deviceObject 
= NULL;
    DbgPrint(
"驅(qū)動(dòng)程序加載\n");
    RtlInitUnicodeString(
&ntDeviceName,NT_DEVICE_NAME);
    ntStatus 
= IoCreateDevice(
        DriverObject,
        
0,
        
&ntDeviceName,
        FILE_DEVICE_UNKNOWN,
        
0,
        FALSE,
        
&deviceObject);

    
if(!NT_SUCCESS(ntStatus))
    
{
        DbgPrint(
"無法創(chuàng)建驅(qū)動(dòng)設(shè)備");
        
return ntStatus;
    }

    RtlInitUnicodeString(
&DeviceLinkString,DOS_DEVICE_NAME);
    ntStatus 
= IoCreateSymbolicLink(&DeviceLinkString,&ntDeviceName);
    
if(!NT_SUCCESS(ntStatus))
    
{
        DbgPrint(
"無法創(chuàng)建驅(qū)動(dòng)設(shè)備");
        
return ntStatus;
    }

    DriverObject
->MajorFunction[IRP_MJ_CREATE] = DispatchDeviceControl;
    DriverObject
->MajorFunction[IRP_MJ_CLOSE] = DispatchDeviceControl;
    DriverObject
->MajorFunction[IRP_MJ_DEVICE_CONTROL] = DispatchDeviceControl;
    DriverObject
->DriverUnload = OnUnload;

    DbgPrint(
"驅(qū)動(dòng)程序已經(jīng)啟動(dòng)\n");
    DbgPrint(
"修改SSDT\n");

    OldZwOpenProcess 
= (ZWOPENPROCESS)(SYSTEMSERVICE(ZwOpenProcess));
    (ZWOPENPROCESS)(SYSTEMSERVICE(ZwOpenProcess)) 
= NewZwOpenProcess;
    DbgPrint(
"驅(qū)動(dòng)程序加載完畢\n");
    
return STATUS_SUCCESS;
}

 
服務(wù)安裝程序:
// ProtectInstaller.cpp : Defines the entry point for the console application.
//

#include 
"stdafx.h"

#define BUF_SIZE 4096

int main(int argc, char* argv[])
{
    
char path[BUF_SIZE];
    
char base[BUF_SIZE];
    
char sername[BUF_SIZE];
    
char disname[BUF_SIZE];
    memset(path,
0,BUF_SIZE);
    memset(
base,0,BUF_SIZE);
    memset(sername,
0,BUF_SIZE);
    memset(disname,
0,BUF_SIZE);

    SC_HANDLE rh 
= NULL;
    SC_HANDLE sh 
= NULL;
    
if(argc == 1)
    
{
        printf(
"use:install/start/uninstall\n");
        exit(
0);
    }


    ::GetModuleFileName(
0,base,BUF_SIZE);
    
int p = strlen(base);
    
while(base[p] != '\\'){ p --; }
    strncpy(path,
base,p+1);
    memset(
base,0,BUF_SIZE);
    sprintf(
base,"%sInstall.ini",path);
    memset(path,
0,BUF_SIZE);

    ::GetPrivateProfileString(
"Config","Path","",path,BUF_SIZE,base);
    ::GetPrivateProfileString(
"Config","ServiceName","",sername,BUF_SIZE,base);
    ::GetPrivateProfileString(
"Config","DisplayName","",disname,BUF_SIZE,base);

    printf(
"[*]Service Name:%s\n",sername);
    printf(
"[*]Display Name:%s\n",disname);
    printf(
"[*]Driver Path:%s\n",path);
    sh 
= OpenSCManager(NULL,NULL,SC_MANAGER_ALL_ACCESS);

    
if(!sh){
        printf(
"[-]Error OpenSCManager.\n");
        exit(
0);
    }

    
if(argc == 2 && !strcmp(argv[1],"install"))
    
{
        
if(!strcmp(path,""))
        
{
            printf(
"[-]error read Install.ini\n");
            exit(
0);
        }

        rh 
= CreateService(sh,
            sername,
            disname,
            SERVICE_ALL_ACCESS,
            SERVICE_KERNEL_DRIVER,
            SERVICE_DEMAND_START,
            SERVICE_ERROR_NORMAL,
            path,
            NULL,NULL,NULL,NULL,NULL);
        
if(!rh)
        
{
            printf(
"[-]error CreateService.\n");
            exit(
0);
        }

        printf(
"[-]Install Service Complete\n");
    }

    
else if(argc == 2 && !strcmp(argv[1],"start"))
    
{
        rh 
= OpenService(sh,sername,SERVICE_ALL_ACCESS);
        
if(!rh)
        
{
            printf(
"[-]error OpenService.\n");
            exit(
0);
        }

        StartService(rh,NULL,NULL);
        printf(
"[-]Start Service Complete\n");
    }

    
else if(argc == 2 && !strcmp(argv[1],"uninstall"))
    
{
        rh 
= OpenService(sh,sername,SERVICE_ALL_ACCESS);
        
if(!rh)
        
{
            printf(
"[-]error OpenService.\n");
            exit(
0);
        }

        SERVICE_STATUS ss;
        ControlService(rh,SERVICE_CONTROL_STOP,
&ss);
        printf(
"[-]Stop Service Complete\n");
        DeleteService(rh);
        printf(
"[-]Delete Service Complete\n");
    }

    CloseServiceHandle(rh);
    CloseServiceHandle(sh);
    
return 1;
}



INI文件:
[Config]
Path
=D:\hacker\ddk\Protect\sys\i386\Protect.sys
ServiceName
=Rootkit
DisplayName
=RootkitKernel

VC05搞了個(gè)解決方案

 


驅(qū)動(dòng)編譯通過了,安裝程序也通過了,也能啟動(dòng),
打開DeviceTree看看,搜索 ProtectProcess,找到了:


現(xiàn)在輪到告訴驅(qū)動(dòng)PID的程序:
#include <stdio.h>
#include 
<stdlib.h>
#include 
<windows.h>
#include 
<winioctl.h>

#ifndef _WIN32_WINNT        
// Allow use of features specific to Windows XP or later.                   
#define _WIN32_WINNT 0x0501    // Change this to the appropriate value to target other versions of Windows.
#endif

#undef UNICODE

#define IOCTL_HELLO_CONTROL CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS)

int main(int argc,char* argv[])
{
    
long pid = 0;
    
char ret[4096];
    DWORD ReBytes 
= 0;
    HANDLE hDevice 
= CreateFile(L"\\\\.\\ProtectProcess",GENERIC_READ|GENERIC_WRITE,0,NULL,
        OPEN_EXISTING,FILE_ATTRIBUTE_NORMAL,NULL);
    
if(hDevice == INVALID_HANDLE_VALUE)
    
{
        
if(2 == GetLastError())
        
{
            printf(
"驅(qū)動(dòng)程序未注冊(cè)\n");
        }

        
else
        
{
            printf(
"CreateFile() GetLastError reports %d \n",GetLastError());            
        }

        
return FALSE;
    }

    memset(ret,
0,4096);
    printf(
"請(qǐng)輸入要保護(hù)的進(jìn)程PID");
    scanf(
"%ld",&pid);
    DeviceIoControl(hDevice,IOCTL_HELLO_CONTROL,
        
&pid,sizeof(long),ret,4096,&ReBytes,NULL);
    printf(
"Return Value:%s\n",ret);
    CloseHandle(hDevice);
    
return 1;
}

開始的時(shí)候,在 CreateFile的第一個(gè)參數(shù)那里犯了一個(gè)錯(cuò)誤,沒有在前面加上“L”,結(jié)果一個(gè)下午花了3個(gè)小時(shí)在煩躁,一直提示驅(qū)動(dòng)未安裝,現(xiàn)在好了,PASS。

啟動(dòng)記事本,找到pid,運(yùn)行通信程序,輸入pid,打開任務(wù)管理器,好了,現(xiàn)在殺不掉notepad.exe了:


很有意思。



青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲国产成人精品女人久久久 | 一区二区三区 在线观看视频| 六月丁香综合| 狂野欧美一区| 欧美bbbxxxxx| 亚洲第一页在线| 老鸭窝毛片一区二区三区| 午夜精品一区二区在线观看 | 欧美激情第五页| 嫩草影视亚洲| 亚洲第一伊人| 亚洲欧洲免费视频| 欧美在线91| 免费成人毛片| 99精品热视频只有精品10| 亚洲男人的天堂在线观看| 久久精品九九| 欧美日韩成人综合在线一区二区 | 亚洲电影毛片| 亚洲日本免费电影| 亚洲精华国产欧美| 亚洲精品国产精品国产自| 亚洲美女啪啪| 久久精品99久久香蕉国产色戒| 久热成人在线视频| 亚洲人成人一区二区在线观看| 亚洲无限av看| 欧美大胆人体视频| 国产亚洲一区二区三区| 亚洲精品久久久一区二区三区| 欧美在线日韩| 99精品久久| 美女久久一区| 国产最新精品精品你懂的| 99亚洲视频| 久久理论片午夜琪琪电影网| 亚洲精品欧美极品| 久久一区二区视频| 日韩视频在线观看| 久久精品国产99国产精品| 久久漫画官网| 国产欧美一区二区精品秋霞影院| 日韩视频在线免费观看| 久久亚洲国产精品一区二区 | 欧美电影免费观看高清| 亚洲欧美日韩爽爽影院| 欧美日韩另类丝袜其他| 亚洲国产精品va在线观看黑人| 欧美一进一出视频| 一本色道88久久加勒比精品| 欧美成年人视频网站| 狠狠做深爱婷婷久久综合一区| 亚洲一区三区电影在线观看| 亚洲精品免费在线播放| 久久久女女女女999久久| 亚洲三级视频| 亚洲精品久久久久中文字幕欢迎你| 午夜精品久久久久久久久| 欧美日韩国产丝袜另类| 亚洲日本中文| 亚洲欧洲一区| 欧美第一黄色网| 亚洲日韩欧美视频| 亚洲国产综合视频在线观看| 免费日韩成人| 亚洲激情视频在线播放| 欧美va日韩va| 欧美aa国产视频| 91久久精品美女高潮| 亚洲缚视频在线观看| 女人香蕉久久**毛片精品| 91久久中文字幕| 亚洲精品国产精品国自产观看浪潮 | 一区二区欧美在线| 亚洲乱亚洲高清| 国产精品夫妻自拍| 欧美亚洲三级| 欧美在线地址| 亚洲激情视频在线播放| 亚洲精品三级| 国产女主播在线一区二区| 久久久www| 欧美阿v一级看视频| 亚洲美女毛片| 国产精品99久久久久久久女警| 国产精品一二三四区| 99在线观看免费视频精品观看| 久热精品视频在线观看| 久久精品国产视频| 在线观看亚洲视频| 欧美国产综合视频| 欧美片网站免费| 先锋影院在线亚洲| 老司机精品视频一区二区三区| 99国产一区| 午夜精品一区二区三区在线播放| 在线欧美福利| 99香蕉国产精品偷在线观看| 国产一区成人| 亚洲日本视频| 狠狠色狠狠色综合系列| 亚洲国产综合在线看不卡| 国产精品美女午夜av| 裸体女人亚洲精品一区| 欧美日韩视频在线一区二区 | 久久综合久久美利坚合众国| 亚洲激情影院| 亚洲午夜一区| 在线播放中文字幕一区| 99在线热播精品免费99热| 伊人久久大香线蕉综合热线| 夜夜嗨av一区二区三区网页| 亚洲大胆女人| 亚洲中字黄色| 久久成年人视频| 一区二区三区四区国产精品| 久久婷婷麻豆| 久久国产色av| 欧美日韩一区二| 欧美大片在线观看一区| 国产在线视频不卡二| 欧美日韩亚洲不卡| 欧美一级大片在线观看| 亚洲视频在线看| 久久人人97超碰精品888| 亚洲国产一成人久久精品| 国产精品视频一区二区高潮| 欧美高清视频免费观看| 国产一区二区三区免费不卡| 9色精品在线| 亚洲国产三级在线| 久久狠狠久久综合桃花| 久久成人18免费网站| 国产精品久久久久婷婷| 亚洲黄色视屏| 亚洲国产va精品久久久不卡综合| 性久久久久久久久久久久| 亚洲欧美韩国| 国产精品高清免费在线观看| 亚洲免费观看高清在线观看 | 香蕉久久夜色精品国产| 久久久久久尹人网香蕉| 欧美国产日本韩| 欧美成人免费一级人片100| 国产一区二区成人| 亚洲欧美一区二区激情| 欧美一级欧美一级在线播放| 国产女优一区| 欧美一区二区三区四区夜夜大片 | 久久精品中文| 黄色小说综合网站| 久久久午夜电影| 欧美成人综合网站| 亚洲精品日韩欧美| 欧美日韩亚洲一区二区| 亚洲一区二区精品| 久久久久久色| 亚洲人成网站在线观看播放| 国产日韩欧美在线播放| 国产精品久久久久久模特| 亚洲麻豆视频| 午夜日韩激情| 黑丝一区二区| 女主播福利一区| 99精品国产在热久久下载| 欧美伊人精品成人久久综合97| 国产精品―色哟哟| 久久免费视频在线观看| 最新日韩在线视频| 午夜视频在线观看一区| 一区二区三区在线看| 欧美精品日韩精品| 性久久久久久久久久久久| 亚洲国产老妈| 性感少妇一区| 亚洲另类视频| 99国产一区| 国精产品99永久一区一区| 午夜久久久久久| 欧美jjzz| 欧美在线啊v一区| 日韩视频一区二区| 国产在线观看91精品一区| 欧美成人免费va影院高清| 亚洲一区在线免费观看| 亚洲大胆女人| 校园春色国产精品| 99视频精品免费观看| 韩国成人精品a∨在线观看| 欧美日韩国产页| 久久人人爽人人爽| 亚洲欧美日韩精品久久久久| 欧美激情一区二区三区在线视频观看 | 久久美女性网| 亚洲精品欧美日韩| 国产欧美一区二区精品仙草咪 | 欧美尤物一区| 亚洲欧美不卡| 99精品免费视频| 含羞草久久爱69一区|