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

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>
            久久久久久69| 在线日韩中文字幕| 亚洲精品欧美精品| 欧美在线不卡| 欧美在线黄色| 欧美性事免费在线观看| 一区二区成人精品| 亚洲一区国产精品| 欧美日韩精品一区视频| 在线亚洲电影| 久久成人免费电影| 亚洲欧美综合另类中字| 国产免费成人在线视频| 欧美一级二区| 亚洲大胆视频| 欧美在线亚洲在线| 午夜亚洲精品| 亚洲高清不卡在线观看| 免费在线看一区| 一本色道久久综合亚洲二区三区| 欧美午夜精品电影| 国产精品腿扒开做爽爽爽挤奶网站| 久久久久久亚洲精品杨幂换脸| 亚洲国产精品久久久久| 午夜精品视频在线观看| 久久aⅴ国产紧身牛仔裤| 久久天堂精品| 夜夜爽av福利精品导航| 亚洲一区二区三区四区视频| 狠狠综合久久| 欧美另类一区二区三区| 香蕉久久夜色| 久久伊人精品天天| 亚洲一区视频在线| 欧美激情第一页xxx| 久久精品成人一区二区三区 | 久久久精品动漫| 99精品国产在热久久婷婷| 久久天堂成人| 亚洲精品久久久久久久久久久久久| 久久躁日日躁aaaaxxxx| 黄色国产精品一区二区三区| 亚洲国产裸拍裸体视频在线观看乱了中文 | 亚洲图片欧美一区| 亚洲第一在线视频| 亚洲午夜一区| 欧美freesex8一10精品| av成人动漫| 美女精品在线| 久色成人在线| 午夜精品久久久久久久99热浪潮| 一区二区三区欧美| 另类av导航| 国产精一区二区三区| 日韩网站在线看片你懂的| 亚洲精品视频一区二区三区| 欧美在线亚洲在线| 妖精视频成人观看www| 美女性感视频久久久| 国产色产综合产在线视频| 国产精品视频1区| 99精品视频免费| 欧美成人免费一级人片100| 欧美成人午夜激情在线| 亚洲一区二区三区视频播放| 欧美日韩大陆在线| 日韩视频一区二区在线观看 | 亚洲欧美偷拍卡通变态| 亚洲高清视频在线观看| 久久精品99国产精品日本 | 美女精品自拍一二三四| 欧美成人精品在线观看| 午夜精品影院在线观看| 国产精品久久久久天堂| 国产欧美日韩视频| 亚洲第一区在线| 久久久久久9| 久久国产夜色精品鲁鲁99| 国产一区av在线| 亚洲免费大片| 亚洲国产精品一区二区第一页 | 亚洲精品资源| 亚洲天堂视频在线观看| 久久久久国产精品www| 国产精品亚洲综合一区在线观看| 欧美婷婷在线| 国产亚洲成年网址在线观看| 性欧美大战久久久久久久免费观看 | 久久综合狠狠综合久久综青草| 国产麻豆综合| 久久精品在线播放| 久久先锋影音| 亚洲精选一区二区| 99精品国产福利在线观看免费| 欧美视频一二三区| 久久www免费人成看片高清| 久久gogo国模裸体人体| 91久久国产精品91久久性色| 一区二区三区日韩欧美| 欧美一级在线播放| 欧美国内亚洲| 欧美日韩在线视频一区| 久久国产天堂福利天堂| 久久午夜羞羞影院免费观看| 一区二区三区视频观看| 欧美一级在线亚洲天堂| 亚洲国产色一区| 一区二区三区四区蜜桃| 国产亚洲欧美一区二区| 亚洲黄页一区| 久久久久成人精品| 亚洲伦理久久| 亚洲自拍啪啪| 欧美日韩国产色视频| 亚洲欧美国内爽妇网| 亚洲人成网站精品片在线观看| 欧美三级小说| 美女视频黄免费的久久| 欧美人成网站| 久久免费99精品久久久久久| 亚洲欧美综合网| 亚洲高清视频一区| 久久激情五月激情| 欧美黄色一区| 亚洲激情不卡| 亚洲一二三区在线观看| 亚洲电影自拍| 午夜欧美精品| 亚洲资源av| 欧美韩日高清| 久久久亚洲一区| 国产精品久久久久久久电影| 亚洲一区二区三区午夜| 久久亚洲高清| 欧美肉体xxxx裸体137大胆| 美日韩免费视频| 国产一区二区三区黄视频| 亚洲日韩欧美视频| 亚洲国产精品va在看黑人| 亚洲专区一区二区三区| 欧美高清不卡| 欧美国产欧美综合| 在线欧美小视频| 久久激情一区| 久久精品国产亚洲精品| 国产精品分类| aa成人免费视频| 欧美电影免费观看| 亚洲精品在线免费观看视频| 欧美专区在线播放| 久久精品麻豆| 国产一区91精品张津瑜| 欧美亚洲一级| 久久亚洲二区| 在线观看亚洲精品视频| 亚洲美女精品成人在线视频| 亚洲国产精品一区二区尤物区| 久久亚洲综合色| 欧美成年人视频| 亚洲人成在线观看| 欧美精品久久99| 久久久久国产一区二区| 国产欧美一区二区精品秋霞影院 | 欧美亚洲日本国产| 欧美日韩高清不卡| 亚洲精品在线视频| 夜夜精品视频| 国产精品久久久久一区二区三区共| 一区二区三区四区五区精品| 欧美在线一二三| 精品成人在线观看| 一本色道久久| 亚洲欧美欧美一区二区三区| 国产精品嫩草影院av蜜臀| 午夜精品99久久免费| 久热这里只精品99re8久| 欧美日韩一区二区三区在线| 久久免费精品日本久久中文字幕| 国产主播精品在线| 亚洲无线观看| 欧美在线一级视频| 亚洲国产综合在线| 欧美精品在线免费| 先锋影音久久久| 欧美激情影院| 午夜精品久久久久久久久 | 久久亚洲私人国产精品va媚药| 久热精品在线视频| 一区二区三区久久精品| 国模套图日韩精品一区二区| 欧美国产亚洲另类动漫| 亚洲在线不卡| 亚洲国产精品一区二区第一页| 亚洲欧美日韩在线综合| 亚洲成人在线| 国产欧美日韩在线观看| 欧美精品一区在线播放| 久久久久久久久久久久久女国产乱| 亚洲精品免费网站| 美女91精品|