首页
社区
课程
招聘
一个小型的用于监视进程产生和撤销驱动逆向分析
发表于: 2007-1-22 13:13 9805

一个小型的用于监视进程产生和撤销驱动逆向分析

2007-1-22 13:13
9805

前两天,闪电狼兄给了一个Themida_1.0.0.5加壳的新版绝影凯旋vip1.65,
狼把它目录中一个驱动NTProcDrv.sys让偶分析分析,注意这不是Themida_1.0.0.5驱动,不过它也保护这Themida加壳的主程序.早前错认了!

由于偶是菜鸟加壳盲.只好"雾"里看花去捏裸笨的NTProcDrv.sys.

作者声明: 只是感兴趣,没有其他目的。失误之处敬请诸位大侠赐教!
由于我误解了狼兄错认它是Themida的驱动.错误改过来了!
谢谢7楼西裤兄,不过代码全部是自己逆地.

逆向一下:

1:设备对象自定义扩展结构体如下:
typedef struct _DeviceExtension {   
                 ULONG size;            //0x0                   
                 PHANDLE  EventHandle;  //0x04
                 PRKEVENT KernelEvent;   //+0x08
                 HANDLE ParentId;      //+0x0C
                 HANDLE ProcessId;    //+0x010
                 ULONG IsCreate;      //+0x014
                } NTProcDrvDeviceExtension;

2:IRP_MJ_DEVICE_CONTROL中是点关键东东.

3:IoCreateNotificationEvent 建立事件通知与下面的回调和exe交互

4:PsSetCreateProcessNotifyRoutine 进程事件回调

由于偶是菜鸟加壳盲,不敢碰Themida_1.0.0.5加壳的EXE.只好找软肋逆.
代码如下:

//////////////////////////////////////////////////////////////////////////////
//          *           NTProcDrv.sys              *      
//          *     be  reversed by qiweixue[BCG]    *
//          *    CopyRight:http:\\www.pediy.com    *     
/////////////////////////////////////////////////////////////////////////////

#include <ntddk.h>
#define NTProcDrv_IOCTL_METHOD_BUFFERED  0x22E000

typedef struct _DeviceExtension {   
                 ULONG size;            //0x0                   
                 PHANDLE  EventHandle;  //0x04
                 PRKEVENT KernelEvent;   //+0x08
                 HANDLE ParentId;      //+0x0C
                 HANDLE ProcessId;    //+0x010
                 ULONG IsCreate;      //+0x014
                } NTProcDrvDeviceExtension;  

               
VOID
NTProcDrvUnloadDriver(
    IN PDRIVER_OBJECT       DriverObject
    );
   
NTSTATUS   
NTProcDrvCreateClose(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp
    );  
      
NTSTATUS
NTProcDeviceControl(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp
    );
      
VOID
NTProcDrvNotifyRoutine (
    IN HANDLE  ParentId,
    IN HANDLE  ProcessId,
    IN BOOLEAN  Create
    );

UNICODE_STRING  DeviceNameString;   
UNICODE_STRING  LinkDeviceNameString;   
UNICODE_STRING  EventDeviceNameString;  
PDEVICE_OBJECT  GloalDeviceObject;

NTSTATUS
DriverEntry(
    IN PDRIVER_OBJECT  DriverObject,
    IN PUNICODE_STRING RegistryPath
    )

{
       
        HANDLE  HEventHandle;
        PKEVENT PEnvent;
  PDEVICE_OBJECT  deviceObject = NULL;  
  NTSTATUS ntStatus;  
  NTProcDrvDeviceExtension            *DevExt=NULL;
  
  RtlInitUnicodeString( &DeviceNameString,    L"\\Device\\NTProcDrv" );
  RtlInitUnicodeString( &LinkDeviceNameString,L"\\DosDevices\\NTProcDrv");
  
  ntStatus = IoCreateDevice(
                DriverObject,
                sizeof(NTProcDrvDeviceExtension),                     
                &DeviceNameString,
                 FILE_DEVICE_UNKNOWN,
                 0,
                 FALSE,
                &deviceObject );

    if (!NT_SUCCESS( ntStatus ))
    {

        return ntStatus;
    }

   ntStatus = IoCreateSymbolicLink(
                (PUNICODE_STRING) &LinkDeviceNameString,
                (PUNICODE_STRING) &DeviceNameString
                );

   if (!NT_SUCCESS(ntStatus))
    {
        IoDeleteDevice(deviceObject);
        return ntStatus;
    }
     GloalDeviceObject=deviceObject;
    DriverObject->DriverUnload =NTProcDrvUnloadDriver;
   
    DriverObject->MajorFunction[IRP_MJ_CREATE] = NTProcDrvCreateClose;
    DriverObject->MajorFunction[IRP_MJ_CLOSE] = NTProcDrvCreateClose;
    DriverObject->MajorFunction[IRP_MJ_DEVICE_CONTROL] = NTProcDeviceControl;   
   
    RtlInitUnicodeString(&EventDeviceNameString,L"\\BaseNamedObjects\\NTProcDrvProcessEvent");
   
    PEnvent=IoCreateNotificationEvent(
                          &EventDeviceNameString,
                          DevExt->EventHandle
                          );   
   DevExt=(NTProcDrvDeviceExtension*)(deviceObject->DeviceExtension);
   DevExt->KernelEvent=PEnvent;
   KeClearEvent(DevExt->KernelEvent);
   
   ntStatus= PsSetCreateProcessNotifyRoutine((PCREATE_PROCESS_NOTIFY_ROUTINE)NTProcDrvNotifyRoutine,0);
   
    return ntStatus;
}
  
  
void
NTProcDrvUnloadDriver(
    IN PDRIVER_OBJECT DriverObject
    )
{
    PDEVICE_OBJECT deviceObject = DriverObject->DeviceObject;
    IoDeleteSymbolicLink( &LinkDeviceNameString );  
    if ( deviceObject != NULL )
    {
        IoDeleteDevice( deviceObject );
    }
}

NTSTATUS
NTProcDrvCreateClose(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp
    )   
{
    Irp->IoStatus.Status = STATUS_SUCCESS;   
    Irp->IoStatus.Information = 0;  
    IoCompleteRequest( Irp, IO_NO_INCREMENT );
    return STATUS_SUCCESS;
}

NTSTATUS
NTProcDeviceControl(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp
    )
{   
       
          NTSTATUS  ntStatus;
          ULONG   IoCtlCode;
    PIO_STACK_LOCATION  IrpStack;
    ULONG               inBufLength;
    ULONG               outBufLength;
    PVOID               InOutBuf;
    NTProcDrvDeviceExtension            *DevExt=NULL;
  
    ntStatus=STATUS_UNSUCCESSFUL;
    IrpStack = IoGetCurrentIrpStackLocation(Irp);//+60
    outBufLength = IrpStack->Parameters.DeviceIoControl.OutputBufferLength;//+4
    inBufLength = IrpStack->Parameters.DeviceIoControl.InputBufferLength;//+8
    IoCtlCode =IrpStack->Parameters.DeviceIoControl.IoControlCode; //C
    InOutBuf = Irp->AssociatedIrp.SystemBuffer;   
    switch(IoCtlCode)
    {
          
           case NTProcDrv_IOCTL_METHOD_BUFFERED:
  
                     if(outBufLength<0x0C)break;  
                     DevExt=(NTProcDrvDeviceExtension*)DeviceObject->DeviceExtension;
                    *((PLONG)InOutBuf)=(ULONG) (DevExt->ParentId);
                    *((PLONG)InOutBuf+1)=(ULONG)(DevExt->ProcessId);
                    *((PLONG)InOutBuf+2)=(char)(DevExt->IsCreate);
                     ntStatus=STATUS_SUCCESS;
           break;
       
  default:
                   Irp->IoStatus.Status = ntStatus;  
                   if(!NT_SUCCESS(ntStatus))
                           {
                                   Irp->IoStatus.Information = outBufLength;       
                           }                
           Irp->IoStatus.Information = outBufLength;                                 
   }
  
   IofCompleteRequest(Irp,IO_NO_INCREMENT);
   
   return ntStatus;
}
   
void
NTProcDrvNotifyRoutine (
    IN HANDLE  ParentId,
    IN HANDLE  ProcessId,
    IN BOOLEAN  Create
    )
{

        PDEVICE_OBJECT  deviceObject=NULL;
        NTProcDrvDeviceExtension  *DevExt=NULL;
        deviceObject=GloalDeviceObject;
  DevExt=deviceObject->DeviceExtension;  
        DevExt->ParentId=ParentId;
        DevExt->ProcessId=ProcessId;
        DevExt->IsCreate=(char)Create;
        KeSetEvent(DevExt->KernelEvent,0,0);
        KeClearEvent(DevExt->KernelEvent);
        return ;
}
           
欢迎找bug.idb文件.c文件,源驱动都在这里
http://www.live-share.com/files/142696/NTProcDrv_sys_c.rar.html
--------------------------------------------------------
我是阿赖耶识


[培训]内核驱动高级班,冲击BAT一流互联网大厂工作,每周日13:00-18:00直播授课

上传的附件:
收藏
免费 7
支持
分享
最新回复 (15)
雪    币: 15212
活跃值: (4973)
能力值: ( LV7,RANK:100 )
在线值:
发帖
回帖
粉丝
2
完全不懂.学习学习..支持七七捏.
2007-1-22 13:19
0
雪    币: 258
活跃值: (230)
能力值: ( LV12,RANK:770 )
在线值:
发帖
回帖
粉丝
3
谢谢,老大.这是偶第一篇在脱壳区的精华文章.
真惭愧.偶是灌水来的

抱歉!附件等论坛稳定在传上来!!!
2007-1-22 13:19
0
雪    币: 817
活跃值: (1927)
能力值: ( LV12,RANK:2670 )
在线值:
发帖
回帖
粉丝
4
完全不懂,支持七七,支持小胃同学
2007-1-22 13:21
0
雪    币: 146
活跃值: (33)
能力值: ( LV6,RANK:90 )
在线值:
发帖
回帖
粉丝
5
评精速度真快卡,支持...只能看花了....
2007-1-22 13:22
0
雪    币: 50121
活跃值: (20745)
能力值: (RANK:350 )
在线值:
发帖
回帖
粉丝
6
qiweixue 太谦虚了。
加点注释就好了
2007-1-22 13:24
0
雪    币: 116
活跃值: (220)
能力值: ( LV12,RANK:370 )
在线值:
发帖
回帖
粉丝
7
这个不是themida的驱动吧。。。这是监视进程创建与终止的。。。

网上有源代码
2007-1-22 13:33
0
雪    币: 258
活跃值: (230)
能力值: ( LV12,RANK:770 )
在线值:
发帖
回帖
粉丝
8
最初由 xIkUg 发布
这个不是themida的驱动吧。。。这是监视进程创建与终止的。。。

网上有源代码


西裤...
这是闪电狼给我的具体我也不知道.themida壳真不懂的说.
偶扎说这么弱!就让偶菜鸟分析出来捏!这个驱动也保护的它的Exe!

我问问闪电狼兄.

有源代码不早说,害我命苦!!!

是谁的驱动不在呼,学习一下.
本来就是""里看花么!
2007-1-22 13:41
0
雪    币: 238
活跃值: (12)
能力值: ( LV9,RANK:210 )
在线值:
发帖
回帖
粉丝
9
支持,我是水中望月!
2007-1-22 13:47
0
雪    币: 116
活跃值: (220)
能力值: ( LV12,RANK:370 )
在线值:
发帖
回帖
粉丝
10
呵呵。。。谁知道你搞这个呀。。。
干之前先google
2007-1-22 14:03
0
雪    币: 258
活跃值: (230)
能力值: ( LV12,RANK:770 )
在线值:
发帖
回帖
粉丝
11
最初由 kanxue 发布
qiweixue 太谦虚了。
加点注释就好了


老大.等论坛稳定我传上附件,里边的idb很详细的.
最好能有DDK文档或MSDN2003对着看看.
2007-1-22 14:21
0
雪    币: 1969
活跃值: (46)
能力值: (RANK:550 )
在线值:
发帖
回帖
粉丝
12
好好向楼主学习。
2007-1-22 17:30
0
雪    币: 1583
活跃值: (831)
能力值: ( LV13,RANK:370 )
在线值:
发帖
回帖
粉丝
13
     case NTProcDrv_IOCTL_METHOD_BUFFERED:
  
         if(outBufLength<0x0C)break;  
         DevExt=(NTProcDrvDeviceExtension*)DeviceObject->DeviceExtension;
        *((PLONG)InOutBuf)=(ULONG) (DevExt->ParentId);
        *((PLONG)InOutBuf+1)=(ULONG)(DevExt->ProcessId);
        *((PLONG)InOutBuf+2)=(char)(DevExt->IsCreate);
         ntStatus=STATUS_SUCCESS;
     break;


这个case里貌似没有对Irp->IoStatus.Status和Irp->IoStatus.Information赋值哦,尤其是Information没有赋值,ring3能拿到正确的结构的话难道是传说中的运气?
2007-1-23 22:13
0
雪    币: 116
活跃值: (220)
能力值: ( LV12,RANK:370 )
在线值:
发帖
回帖
粉丝
14
只要他的InOutBuf有足够的空间就是安全的,可以不对Irp->IoStatus.Status和Irp->IoStatus.Information赋值(size是固定的)
2007-1-23 23:02
0
雪    币: 258
活跃值: (230)
能力值: ( LV12,RANK:770 )
在线值:
发帖
回帖
粉丝
15
谢谢老罗!!!
把上边的break;去掉再把//default:注释掉就可以.粗心一下!
       Irp->IoStatus.Status = ntStatus;  
       if(!NT_SUCCESS(ntStatus))
         {
           Irp->IoStatus.Information = outBufLength;  
         }     
     Irp->IoStatus.Information = outBufLength;  
2007-1-24 08:32
0
雪    币: 200
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
16
怎样进行逆向工程,楼上的老大能不能解释一下,或给点参考资料,小弟谢了
2007-1-26 07:38
0
游客
登录 | 注册 方可回帖
返回
// // 统计代码