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

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>
            香港成人在线视频| 亚洲国产精品福利| 老色批av在线精品| 亚洲国产日韩欧美综合久久| 国产一区二区在线观看免费播放 | 午夜精品久久久久久久久久久| 国产精品影片在线观看| 久久久久久一区二区| 亚洲激情中文1区| 欧美一区二区高清在线观看| 在线免费观看日本欧美| 欧美伦理视频网站| 午夜亚洲一区| 日韩亚洲国产欧美| 玖玖精品视频| 亚洲欧美电影院| 亚洲国产mv| 国产日韩欧美一区二区| 欧美精品久久久久久久免费观看| 99天天综合性| 欧美福利在线| 久久成人精品| 亚洲午夜一区| 亚洲免费播放| 1000部精品久久久久久久久| 国产精品老牛| 欧美视频一区二区三区四区| 免费在线看一区| 欧美一区二区视频在线观看| av成人免费| 亚洲人成免费| 欧美国产日韩视频| 免费看亚洲片| 六月婷婷一区| 久久久www成人免费无遮挡大片| 中日韩视频在线观看| 亚洲激情自拍| 亚洲国产精品毛片| 一区在线免费观看| 国产欧美一区二区三区在线老狼 | 亚洲精品一区二区在线| 亚洲国产天堂久久综合网| 在线播放一区| 国产欧美日韩免费看aⅴ视频| 男人插女人欧美| 久久精品在线观看| 欧美在线网址| 久久国产精品黑丝| 亚洲欧美日韩天堂一区二区| 亚洲天堂成人| 亚洲一区二区三区777| 一本不卡影院| 一本色道久久综合狠狠躁篇怎么玩| 欧美激情2020午夜免费观看| 免费在线观看成人av| 久久免费一区| 久久嫩草精品久久久精品一| 久久不见久久见免费视频1| 亚洲欧美成人| 久久福利一区| 久久久国产精彩视频美女艺术照福利 | 欧美在线不卡| 久久亚洲精品视频| 欧美v国产在线一区二区三区| 欧美成人dvd在线视频| 欧美国产日韩一二三区| 欧美日韩国产黄| 国产精品一区二区欧美| 国产一区二区三区四区| 国产专区综合网| 亚洲靠逼com| 亚洲免费视频网站| 久久精选视频| 亚洲精品国产视频| 亚洲伊人久久综合| 麻豆91精品91久久久的内涵| 欧美国产先锋| 欧美日韩国产成人在线免费| 国产精品国产三级国产a| 国产一区二区在线观看免费播放 | 欧美大片免费观看| 国产精品毛片一区二区三区| 激情文学综合丁香| 一本色道综合亚洲| 久久久久这里只有精品| 亚洲黄色av一区| 午夜亚洲视频| 欧美日韩一区在线播放| 新狼窝色av性久久久久久| 久久免费的精品国产v∧| 欧美日韩激情小视频| 黄色成人小视频| 亚洲资源av| 亚洲观看高清完整版在线观看| 中文在线一区| 美日韩精品免费| 国产视频久久久久久久| 日韩亚洲视频在线| 另类图片综合电影| 亚洲欧美综合v| 欧美日韩一区二区三区| 亚洲国产精品日韩| 久久精品一区| 亚洲综合激情| 欧美日韩和欧美的一区二区| 亚洲国产美女| 久久久免费精品视频| 中文欧美在线视频| 欧美韩日精品| 亚洲欧洲在线一区| 久久尤物视频| 久久国产主播| 国产女人精品视频| 亚洲欧美视频一区| 日韩视频在线一区| 欧美精品一区二区三区久久久竹菊 | 欧美一区二区私人影院日本| 亚洲国产精品v| 美女啪啪无遮挡免费久久网站| 国产一区二区三区的电影 | 久久久久久亚洲综合影院红桃| 国产欧美日韩精品专区| 午夜视频一区在线观看| 一区二区久久久久久| 欧美日韩伦理在线免费| 99视频精品在线| 一本大道久久a久久精品综合| 欧美精品成人一区二区在线观看 | 99国产精品久久久久久久成人热 | 欧美日韩一区二区三| 亚洲资源av| 午夜影院日韩| 激情综合色综合久久综合| 久久久亚洲人| 久久一区中文字幕| 欧美成人福利视频| 国产精品久久久久久av下载红粉| 老司机午夜精品| 伊人一区二区三区久久精品| 看欧美日韩国产| 欧美.www| 一区二区三区产品免费精品久久75 | 久色成人在线| 亚洲乱码国产乱码精品精天堂| 亚洲国产裸拍裸体视频在线观看乱了| 欧美阿v一级看视频| 亚洲美女在线看| 亚洲午夜女主播在线直播| 国产日韩欧美综合精品| 免费在线欧美黄色| 欧美精品一区二区精品网 | 欧美日韩精品系列| 欧美一区二区精品| 久久久欧美精品sm网站| 亚洲精品一区二区三区不| 一区二区三区回区在观看免费视频| 国产精品第十页| 免费一区二区三区| 欧美亚男人的天堂| 蜜臀99久久精品久久久久久软件| 欧美日本韩国| 久久色在线观看| 欧美丝袜一区二区| 欧美成人精精品一区二区频| 欧美日韩精品| 蜜桃av综合| 欧美日韩中文精品| 免费成人美女女| 国产精品久久久久久久久动漫| 欧美成人一区二区三区在线观看| 欧美亚洲成人网| 亚洲盗摄视频| 国产一区二区三区最好精华液| 亚洲精品一区在线观看香蕉| 国内精品伊人久久久久av影院 | 欧美一区二区精品| 欧美日韩高清不卡| 玖玖玖国产精品| 国产婷婷成人久久av免费高清| 亚洲国产黄色| 亚洲大片在线观看| 久久成人亚洲| 欧美一区二区视频在线| 欧美日韩一区二区在线观看视频| 欧美a级一区| 狠狠色狠狠色综合人人| 一区二区免费看| 在线亚洲免费| 欧美大片在线看| 欧美激情第二页| 尤物视频一区二区| 久久久成人精品| 国产精品综合不卡av| 日韩视频中文字幕| 一二三四社区欧美黄| 欧美成人福利视频| 91久久在线| 亚洲精品视频免费| 欧美大片在线观看一区| 欧美国产日韩视频|