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

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++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

Hook SSDT

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

驅動程序代碼:
#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(
"保護進程 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(
"驅動程序卸載\n");
    RtlInitUnicodeString(
&DeviceLinkString,DOS_DEVICE_NAME);
    IoDeleteSymbolicLink(
&DeviceLinkString);
    
if(DriverObject)
    
{
        DeviceObjectTemp1 
= DriverObject->DeviceObject;
        
while(DeviceObjectTemp1)
        
{
            DeviceObjectTemp2 
= DeviceObjectTemp1;
            DeviceObjectTemp1 
= DeviceObjectTemp1->NextDevice;
            IoDeleteDevice(DeviceObjectTemp2);
        }

    }

    DbgPrint(
"設備已卸載\n");
    DbgPrint(
"修復SSDT\n");
    (ZWOPENPROCESS)(SYSTEMSERVICE(ZwOpenProcess)) 
= OldZwOpenProcess;
    DbgPrint(
"驅動卸載完畢\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 被調用\n");
            
break;
        
case IRP_MJ_CLOSE:
            DbgPrint(
"IRP_MJ_CLOSE 被調用\n");
            
break;
        
case IRP_MJ_DEVICE_CONTROL:
            DbgPrint(
"IRP_MJ_DEVICE_CONTROL 被調用\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 被調用,通訊成功!\n");
                    DbgPrint(
"輸入緩沖區大小:%d\n",inSize);
                    DbgPrint(
"輸出緩沖區大小:%d\n",outSize);
                    DbgPrint(
"輸入緩沖區內容:%ld\n",*inBuf);
                    DbgPrint(
"當前保護進程ID:%ld\n",pid);
                    DbgPrint(
"=========================================\n");
                    
                    strcpy(Irp
->UserBuffer,"OK\n");
                    
break;
                
default:
                    
break;
            }

            
break;
        
default:
            DbgPrint(
"未知請求包被調用\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(
"驅動程序加載\n");
    RtlInitUnicodeString(
&ntDeviceName,NT_DEVICE_NAME);
    ntStatus 
= IoCreateDevice(
        DriverObject,
        
0,
        
&ntDeviceName,
        FILE_DEVICE_UNKNOWN,
        
0,
        FALSE,
        
&deviceObject);

    
if(!NT_SUCCESS(ntStatus))
    
{
        DbgPrint(
"無法創建驅動設備");
        
return ntStatus;
    }

    RtlInitUnicodeString(
&DeviceLinkString,DOS_DEVICE_NAME);
    ntStatus 
= IoCreateSymbolicLink(&DeviceLinkString,&ntDeviceName);
    
if(!NT_SUCCESS(ntStatus))
    
{
        DbgPrint(
"無法創建驅動設備");
        
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(
"驅動程序已經啟動\n");
    DbgPrint(
"修改SSDT\n");

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

 
服務安裝程序:
// 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搞了個解決方案

 


驅動編譯通過了,安裝程序也通過了,也能啟動,
打開DeviceTree看看,搜索 ProtectProcess,找到了:


現在輪到告訴驅動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(
"驅動程序未注冊\n");
        }

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

        
return FALSE;
    }

    memset(ret,
0,4096);
    printf(
"請輸入要保護的進程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;
}

開始的時候,在 CreateFile的第一個參數那里犯了一個錯誤,沒有在前面加上“L”,結果一個下午花了3個小時在煩躁,一直提示驅動未安裝,現在好了,PASS。

啟動記事本,找到pid,運行通信程序,輸入pid,打開任務管理器,好了,現在殺不掉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>
            国产一区日韩一区| 欧美a级大片| 国产一区自拍视频| 国产精品久久久久aaaa樱花| 欧美区一区二| 欧美日本亚洲韩国国产| 欧美日韩免费高清| 国产精品久久久久久久久久久久 | 亚洲一级高清| 一本色道久久综合亚洲精品不卡 | 欧美日韩精品系列| 欧美天堂在线观看| 国际精品欧美精品| 99re66热这里只有精品3直播| 亚洲免费成人av| 午夜亚洲影视| 国产模特精品视频久久久久| 国产精品久久久久免费a∨大胸| 国产精品久久看| 亚洲精品免费电影| 久久成人一区| 99综合电影在线视频| 久久激情中文| 国产精品毛片大码女人| 黑人巨大精品欧美一区二区| 99re成人精品视频| 欧美成人午夜免费视在线看片 | 亚洲无线一线二线三线区别av| 久久av一区二区三区| 国产精品久久久久久久久久久久久 | 亚洲精品国精品久久99热| 欧美一级视频免费在线观看| 欧美搞黄网站| 久久这里只有精品视频首页| 国产欧美短视频| 亚洲欧美另类久久久精品2019| 亚洲欧洲综合| 美女啪啪无遮挡免费久久网站| 国产精品综合视频| 香蕉乱码成人久久天堂爱免费 | 久久国产综合精品| 亚洲欧美日韩精品在线| 国产日韩在线视频| 久久精品99国产精品酒店日本| 亚洲伊人网站| 欧美一区二区在线免费观看| 国产精品久久国产精品99gif| 亚洲免费电影在线| 亚洲精品一级| 国产视频在线观看一区| 欧美成人一区二区三区| 欧美理论电影网| 久久国产精品亚洲77777| 另类av一区二区| 亚洲欧美日韩在线一区| 久久精品一二三区| 一本色道久久综合亚洲精品高清| 一本色道综合亚洲| 亚洲国产成人不卡| 一本到12不卡视频在线dvd| 狠狠色综合一区二区| 亚洲性av在线| 中文网丁香综合网| 久久亚洲一区| 久久精品二区| 国产精品一卡二卡| 亚洲一区二区在线播放| 日韩一级免费观看| 欧美激情视频给我| 欧美激情欧美激情在线五月| 国产区亚洲区欧美区| 一二三区精品| 亚洲欧美资源在线| 国产精品久久久久久久7电影| 欧美激情一二三区| 亚洲日本va午夜在线电影| 麻豆国产精品777777在线| 久久午夜视频| 亚洲品质自拍| 欧美久久久久久久久久| 91久久精品国产| 亚洲午夜小视频| 亚洲综合色视频| 一本色道综合亚洲| 欧美专区在线观看| 欧美亚洲一区在线| 国产一区久久| 欧美freesex8一10精品| 亚洲狠狠丁香婷婷综合久久久| 亚洲国产日韩综合一区| 欧美大片在线观看一区| 亚洲天堂视频在线观看| 久久精品日产第一区二区三区| 亚洲电影观看| 国产精品成人免费| 免费成人黄色片| 亚洲在线播放| 欧美激情aⅴ一区二区三区| 亚洲影院高清在线| 亚洲精品免费看| 亚洲国产成人在线播放| 欧美日韩中文精品| 欧美屁股在线| 欧美国产一区二区三区激情无套| 亚洲视频免费在线观看| 亚洲激情电影中文字幕| 久久一区视频| 欧美在线视频导航| 欧美一区影院| 夜夜狂射影院欧美极品| …久久精品99久久香蕉国产 | 久久裸体艺术| 欧美综合国产| 久久精品一区二区三区中文字幕| 这里只有视频精品| 一区二区三区四区蜜桃| 亚洲自拍都市欧美小说| 99在线精品视频| 亚洲亚洲精品三区日韩精品在线视频| 亚洲精品社区| 日韩一区二区免费看| 一本大道av伊人久久综合| 夜夜爽99久久国产综合精品女不卡| 亚洲精品国产精品国产自| 亚洲精品1区2区| 夜夜狂射影院欧美极品| 欧美一区二区精品| 免费成人毛片| 日韩亚洲欧美成人| 欧美一区二区在线观看| 麻豆91精品| 国产精品美女久久久浪潮软件| 国产日韩精品综合网站| 亚洲国产精品久久91精品| 亚洲美女诱惑| 久久嫩草精品久久久久| 亚洲精品韩国| 久久亚洲精品中文字幕冲田杏梨| 欧美另类视频| 亚洲欧洲三级电影| 在线欧美亚洲| 久久精品人人做人人爽| 久久最新视频| 久久成人国产精品| 国产精品久久一区主播| 亚洲午夜国产一区99re久久| 久久婷婷亚洲| 久久精品国产欧美亚洲人人爽| 欧美午夜不卡视频| 亚洲精选在线观看| 欧美 日韩 国产 一区| 欧美一区二区观看视频| 欧美日韩午夜精品| 亚洲最黄网站| 欧美+日本+国产+在线a∨观看| 亚洲一区三区视频在线观看| 欧美色图首页| 日韩午夜在线视频| 亚洲欧洲综合| 国产精品欧美日韩一区| 欧美制服丝袜| 免费日韩av片| 国产精品免费看久久久香蕉| 一区二区三区精密机械公司 | 国内精品**久久毛片app| 夜夜嗨av色一区二区不卡| 亚洲第一主播视频| 欧美三级在线播放| 久久精品国产一区二区电影 | 欧美一级片一区| 一区二区三区 在线观看视频| 欧美日本免费| 久久久夜精品| 国产精品免费福利| 亚洲高清资源| 黑人一区二区三区四区五区| 欧美大片在线看| 欧美日韩视频不卡| 裸体一区二区| 国产精品久久久久久久久婷婷 | 国产欧美日韩免费| 亚洲国产小视频在线观看| 欧美日韩成人在线播放| 久久亚洲捆绑美女| 国产日韩在线视频| 亚洲免费观看高清完整版在线观看| 国产精品美女999| 亚洲人成久久| 久久久在线视频| 久久裸体艺术| 国产无遮挡一区二区三区毛片日本| 亚洲精品社区| 亚洲激情在线观看| 久久综合国产精品| 亚洲男女毛片无遮挡| 国产精品国产精品| 在线亚洲欧美| 欧美自拍偷拍| 国产伦精品一区二区三区四区免费| 91久久久久久国产精品|