枚举驱动

接着补充一个……驱动枚举

--------------------------------------------------------------------------

代码
//--------------------------------------------------------------------------
// Copyright (C), 2004-2010, Zhengzongzhao, All Rights Reserved
//
// FileName:    EnumDriver.cpp
//
// Author:      zhengzz
//
// Date:        2009-07-20
//
// Description: 枚举驱动
//
// History:     <author>zhengzongzhao<time>2009-07-20<version>1.0
//
//-------------------------------------------------------------------------

#include 
"stdafx.h"
#include 
<windows.h>
#include 
<stdlib.h>
#include 
<stdio.h>

// 定义函数返回值
typedef ULONG NTSTATUS;

// 宽字节字符串结构定义
typedef struct _UNICODE_STRING {
    USHORT  Length;
    USHORT  MaximumLength;
    PWSTR  Buffer;
} UNICODE_STRING, 
*PUNICODE_STRING;

// 对象属性定义
typedef struct _OBJECT_ATTRIBUTES {
    ULONG Length;
    HANDLE RootDirectory;
    UNICODE_STRING 
*ObjectName;
    ULONG Attributes;
    PSECURITY_DESCRIPTOR SecurityDescriptor;
    PSECURITY_QUALITY_OF_SERVICE SecurityQualityOfService;
} OBJECT_ATTRIBUTES,
*POBJECT_ATTRIBUTES;

// 基本信息定义
typedef struct _DIRECTORY_BASIC_INFORMATION {
    UNICODE_STRING ObjectName;
    UNICODE_STRING ObjectTypeName;
} DIRECTORY_BASIC_INFORMATION, 
*PDIRECTORY_BASIC_INFORMATION;

// 返回值或状态类型定义
#define OBJ_CASE_INSENSITIVE    0x00000040L
#define DIRECTORY_QUERY            (0x0001)
#define STATUS_SUCCESS            ((NTSTATUS)0x00000000L) // ntsubauth
#define STATUS_MORE_ENTRIES        ((NTSTATUS)0x00000105L)
#define STATUS_BUFFER_TOO_SMALL    ((NTSTATUS)0xC0000023L)

// 初始化对象属性宏定义
#define InitializeObjectAttributes( p, n, a, r, s ) { \
    (p)
->Length = sizeof( OBJECT_ATTRIBUTES );          \
    (p)
->RootDirectory = r;                             \
    (p)
->Attributes = a;                                \
    (p)
->ObjectName = n;                                \
    (p)
->SecurityDescriptor = s;                        \
    (p)
->SecurityQualityOfService = NULL;               \
    }

// 字符串初始化
typedef VOID (CALLBACK* RTLINITUNICODESTRING)(PUNICODE_STRING,PCWSTR);
RTLINITUNICODESTRING RtlInitUnicodeString;

// 打开对象
typedef NTSTATUS (WINAPI *ZWOPENDIRECTORYOBJECT)(
                      OUT PHANDLE DirectoryHandle,
                      IN ACCESS_MASK DesiredAccess,
                      IN POBJECT_ATTRIBUTES ObjectAttributes
);
ZWOPENDIRECTORYOBJECT ZwOpenDirectoryObject;

// 查询对象
typedef
NTSTATUS
(WINAPI 
*ZWQUERYDIRECTORYOBJECT)(
                       IN HANDLE DirectoryHandle,
                       OUT PVOID Buffer,
                       IN ULONG BufferLength,
                       IN BOOLEAN ReturnSingleEntry,
                       IN BOOLEAN RestartScan,
                       IN OUT PULONG Context,
                       OUT PULONG ReturnLength OPTIONAL
);
ZWQUERYDIRECTORYOBJECT ZwQueryDirectoryObject;

// 关闭已经打开的对象
typedef
NTSTATUS
(WINAPI 
*ZWCLOSE)(
        IN HANDLE Handle
);
ZWCLOSE ZwClose;


int _tmain(int argc, _TCHAR* argv[])
{
    HMODULE hNtdll 
= NULL;

    hNtdll 
= LoadLibrary(_T("ntdll.dll" ));
    
if ( NULL == hNtdll )
    {
        printf(
"[%s]--Load ntdll.dll failed(%ld).\r\n", __FUNCTION__, GetLastError());
        
goto EXIT;
    }

    printf(
"[%s]--Load ntdll.dll sucess now get proc.\r\n", __FUNCTION__);
    RtlInitUnicodeString   
= (RTLINITUNICODESTRING)GetProcAddress( hNtdll, "RtlInitUnicodeString");
    ZwOpenDirectoryObject  
= (ZWOPENDIRECTORYOBJECT)GetProcAddress( hNtdll, "ZwOpenDirectoryObject");
    ZwQueryDirectoryObject 
= (ZWQUERYDIRECTORYOBJECT)GetProcAddress( hNtdll, "ZwQueryDirectoryObject");
    ZwClose                
= (ZWCLOSE)GetProcAddress( hNtdll, "ZwClose");

    UNICODE_STRING     strDirName;
    OBJECT_ATTRIBUTES  oba;
    NTSTATUS           ntStatus; 
    HANDLE             hDirectory;

    RtlInitUnicodeString(
&strDirName, _T("\\Driver"));
    InitializeObjectAttributes(
&oba, &strDirName, OBJ_CASE_INSENSITIVE, NULL, NULL);

    printf(
"[%s]--Open directory object now.\r\n", __FUNCTION__);
    ntStatus
=ZwOpenDirectoryObject(&hDirectory, DIRECTORY_QUERY, &oba);
    
if ( ntStatus != STATUS_SUCCESS )
    {
        printf(
"[%s]--Open directory object failed(%ld).\r\n", __FUNCTION__, GetLastError());
        
goto EXIT;
    }
    printf(
"[%s]--Open directory object success.\r\n", __FUNCTION__);

    PDIRECTORY_BASIC_INFORMATION   pBuffer 
= NULL;
    PDIRECTORY_BASIC_INFORMATION   pBuffer2;
    ULONG    ulLength  
= 0x800;    // 2048
    ULONG    ulContext = 0;
    ULONG    ulRet     
= 0

    
// 查询目录对象
    do
    {
        
if ( pBuffer != NULL )
        {
            free(pBuffer);
        }

        ulLength 
= ulLength * 2;
        pBuffer  
= (PDIRECTORY_BASIC_INFORMATION)malloc(ulLength);
        
if ( NULL == pBuffer )
        {
            printf(
"[%s]--Malloc failed(%ld).\r\n", __FUNCTION__, GetLastError());
            
goto EXIT;
        }

        ntStatus 
= ZwQueryDirectoryObject(hDirectory, pBuffer, ulLength, FALSE, TRUE, &ulContext, &ulRet);
        printf(
"[%s]--ZwQueryDirectoryObject out return is %ld.\r\n", __FUNCTION__, ulRet);
    }
while ( ntStatus == STATUS_MORE_ENTRIES || ntStatus == STATUS_BUFFER_TOO_SMALL );

    
if ( STATUS_SUCCESS == ntStatus )
    {
        printf(
"[%s]--ZwQueryDirectoryObject success.\r\n", __FUNCTION__);
        pBuffer2 
= pBuffer;
        
while ( (pBuffer2->ObjectName.Length != 0&& (pBuffer2->ObjectTypeName.Length!=0) )
        {
            printf(
"ObjectName: [%S]---ObjectTypeName: [%S]\n", pBuffer2->ObjectName.Buffer, pBuffer2->ObjectTypeName.Buffer);
            pBuffer2
++;
        }
    }
    
else
    {
        printf(
"[%s]--ZwQueryDirectoryObject failed(%ld).\r\n", __FUNCTION__, GetLastError());
    }

EXIT:

    
if ( pBuffer != NULL )
    {
        free(pBuffer);
    }

    
if ( hDirectory != NULL )
    {
        ZwClose(hDirectory);
    }

    getchar();
    
return 0;
}


posted @ 2010-04-29 10:16  zhengzongzhao  阅读(777)  评论(0编辑  收藏  举报