亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? filemon.c

?? 文件監視FileMon 一個常用的監視軟件
?? C
?? 第 1 頁 / 共 5 頁
字號:
ULONG 
FilemonGetProcessNameOffset(
    VOID
    )
{
    PEPROCESS       curproc;
    int             i;

    curproc = PsGetCurrentProcess();

    //
    // Scan for 12KB, hoping the KPEB never grows that big!
    //
    for( i = 0; i < 3*PAGE_SIZE; i++ ) {
     
        if( !strncmp( SYSNAME, (PCHAR) curproc + i, strlen(SYSNAME) )) {

            return i;
        }
    }

    //
    // Name not found - oh, well
    //
    return 0;
}


//----------------------------------------------------------------------
//
// FilemonGetProcess
//
// Uses undocumented data structure offsets to obtain the name of the
// currently executing process.
//
//----------------------------------------------------------------------
PCHAR
FilemonGetProcess( 
    PCHAR ProcessName 
    )
{
    PEPROCESS       curproc;
    char            *nameptr;
    ULONG           i;

    //
    // We only do this if we determined the process name offset
    //
    if( ProcessNameOffset ) {
      
        //
        // Get a pointer to the current process block
        //
        curproc = PsGetCurrentProcess();

        //
        // Dig into it to extract the name. Make sure to leave enough room
        // in the buffer for the appended process ID.
        //
        nameptr   = (PCHAR) curproc + ProcessNameOffset;
         
        strncpy( ProcessName, nameptr, NT_PROCNAMELEN-1 );
        ProcessName[NT_PROCNAMELEN-1] = 0;
#if defined(_IA64_)
        sprintf( ProcessName + strlen(ProcessName), ":%I64d", PsGetCurrentProcessId());
#else
        sprintf( ProcessName + strlen(ProcessName), ":%d", PsGetCurrentProcessId());
#endif

    } else {

        strcpy( ProcessName, "???" );
    }
    return ProcessName;
}


//----------------------------------------------------------------------
//          H O O K / U N H O O K   R O U T I N E S
//----------------------------------------------------------------------

#if DBG        
//----------------------------------------------------------------------
//
// UnloadDetach
//
// Detaches from all devices for an unload
//
//----------------------------------------------------------------------
VOID 
UnloadDetach( 
    VOID 
    )
{
    ULONG           drive, i;
    PDEVICE_OBJECT  device;
    PHOOK_EXTENSION hookExt;
    
    //
    // Detach from file system devices
    //
    for( drive = 0; drive < 26; drive++ ) {

        if( DriveHookDevices[drive] ) {

            device = DriveHookDevices[drive];
            hookExt = device->DeviceExtension;
            IoDetachDevice( hookExt->FileSystem );
            IoDeleteDevice( device );

            for( i =0; i < 26; i++ ) {

                if( DriveHookDevices[i] == device ) {

                    DriveHookDevices[i] = NULL;
                }
            }
        }
    }

    //
    // Detach from special devices
    //
    if( NamedPipeHookDevice ) {

        IoDetachDevice( NamedPipeHookDevice );
        IoDeleteDevice( NamedPipeHookDevice );
    }
    if( MailSlotHookDevice ) {

        IoDetachDevice( MailSlotHookDevice );
        IoDeleteDevice( MailSlotHookDevice );
    }
}
#endif // DBG

//----------------------------------------------------------------------
//
// HookSpecialFs
//
// Hook the named pipe or mail slot file system.
//
//----------------------------------------------------------------------
BOOLEAN 
HookSpecialFs( 
    IN PDRIVER_OBJECT DriverObject, 
    FILE_SYSTEM_TYPE FsType 
    )
{
    IO_STATUS_BLOCK     ioStatus;
    HANDLE              ntFileHandle;   
    OBJECT_ATTRIBUTES   objectAttributes;
    PDEVICE_OBJECT      fileSysDevice;
    PDEVICE_OBJECT      topAttachDevice;
    PDEVICE_OBJECT      hookDevice;
    UNICODE_STRING      fileNameUnicodeString;
    WCHAR               npfsFilename[] = L"\\Device\\NamedPipe";
    WCHAR               msfsFilename[] = L"\\Device\\MailSlot";
    NTSTATUS            ntStatus;
    ULONG               i;
    PFILE_OBJECT        fileObject;
    PHOOK_EXTENSION     hookExtension;

    //
    // If we've already hooked it, just return success
    //
    if( FsType == NPFS && NamedPipeHookDevice ) return TRUE;
    if( FsType == MSFS && MailSlotHookDevice ) return TRUE;
    
    //
    // We have to figure out what device to hook - first open the volume's 
    // root directory
    //
    if( FsType == NPFS ) RtlInitUnicodeString( &fileNameUnicodeString, npfsFilename );
    else                 RtlInitUnicodeString( &fileNameUnicodeString, msfsFilename );
    InitializeObjectAttributes( &objectAttributes, &fileNameUnicodeString, 
                                OBJ_CASE_INSENSITIVE, NULL, NULL );
    ntStatus = ZwCreateFile( &ntFileHandle, SYNCHRONIZE|FILE_ANY_ACCESS, 
                             &objectAttributes, &ioStatus, NULL, 0, FILE_SHARE_READ|FILE_SHARE_WRITE, 
                             FILE_OPEN, 
                             FILE_SYNCHRONOUS_IO_NONALERT|FILE_DIRECTORY_FILE, 
                             NULL, 0 );
    if( !NT_SUCCESS( ntStatus ) ) {

        DbgPrint(("Filemon: Could not open %s\n", FsType == NPFS ? "NPFS" : "MSFS", ntStatus ));

        return FALSE;
    }

    DbgPrint(("Filemon:  opened the root directory!!! handle: %x\n", ntFileHandle));   

    //
    // Got the file handle, so now look-up the file-object it refers to
    //
    ntStatus = ObReferenceObjectByHandle( ntFileHandle, FILE_READ_DATA, 
                                          NULL, KernelMode, &fileObject, NULL );
    if( !NT_SUCCESS( ntStatus )) {

        DbgPrint(("Filemon: Could not get fileobject from %s handle: %x\n", 
                  FsType == NPFS ? "NPFS" : "MSFS", ntStatus ));
        ZwClose( ntFileHandle );

        return FALSE;
    }

    //  
    // Next, find out what device is associated with the file object by getting its related
    // device object
    //
    fileSysDevice = IoGetRelatedDeviceObject( fileObject );

    if( ! fileSysDevice ) {

        DbgPrint(("Filemon: Could not get related device object for %s: %x\n", 
                  FsType == NPFS ? "NPFS" : "MSFS", ntStatus ));

        ObDereferenceObject( fileObject );
        ZwClose( ntFileHandle );

        return FALSE;
    }

    //
    // The file system's device hasn't been hooked already, so make a hooking device
    //  object that will be attached to it.
    //
    ntStatus = IoCreateDevice( DriverObject,
                               sizeof(HOOK_EXTENSION),
                               NULL,
                               fileSysDevice->DeviceType,
                               0,
                               FALSE,
                               &hookDevice );
    if( !NT_SUCCESS(ntStatus) ) {

        DbgPrint(("Filemon: failed to create associated device %s: %x\n", 
                  FsType == NPFS ? "NPFS" : "MSFS", ntStatus ));

        ObDereferenceObject( fileObject );
        ZwClose( ntFileHandle );

        return FALSE;
    }

    //
    // Clear the device's init flag as per NT DDK KB article on creating device 
    // objects from a dispatch routine
    //
    hookDevice->Flags &= ~DO_DEVICE_INITIALIZING;

    //
    // Finally, attach to the device. The second we're successfully attached, we may 
    // start receiving IRPs targetted at the device we've hooked.
    //
    topAttachDevice = IoAttachDeviceToDeviceStack( hookDevice, fileSysDevice );
    if( !topAttachDevice )  {

        //
        // Couldn' attach for some reason
        //
        DbgPrint(("Filemon: Connect with Filesystem failed: %s (%x) =>%x\n", 
                  FsType == NPFS ? "NPFS" : "MSFS", fileSysDevice, ntStatus ));

        //
        // Derefence the object and get out
        //
        ObDereferenceObject( fileObject );
        ZwClose( ntFileHandle );

        return FALSE;

    } else {

        DbgPrint(("Filemon: Successfully connected to Filesystem device %s\n",
                  FsType == NPFS ? "NPFS" : "MSFS" ));
    }

    //
    // Setup the device extensions. The drive letter and file system object are stored
    // in the extension.
    //
    hookExtension = hookDevice->DeviceExtension;
    hookExtension->LogicalDrive = '\\';
    hookExtension->FileSystem   = topAttachDevice;
    hookExtension->Hooked       = TRUE;
    hookExtension->Type = FsType;
    
    //
    // Close the file and update the hooked drive list by entering a
    // pointer to the hook device object in it.
    //
    ObDereferenceObject( fileObject );
    ZwClose( ntFileHandle );

    if( FsType == NPFS ) NamedPipeHookDevice = hookDevice;
    else                 MailSlotHookDevice  = hookDevice;

    return TRUE;
}


//----------------------------------------------------------------------
//
// UnhookSpecialFs
//
// Unhook the named pipe file or mail slot system.
//
//----------------------------------------------------------------------
VOID 
UnhookSpecialFs( 
    FILE_SYSTEM_TYPE FsType 
    )
{
    PHOOK_EXTENSION   hookExt;

    if( FsType == NPFS && NamedPipeHookDevice ) {
        
        hookExt = NamedPipeHookDevice->DeviceExtension;
        hookExt->Hooked = FALSE;
        NamedPipeHookDevice = NULL;

    } else if( FsType == MSFS && MailSlotHookDevice ) {

        hookExt = MailSlotHookDevice->DeviceExtension;
        hookExt->Hooked = FALSE;
        MailSlotHookDevice = NULL;
    }
}


//----------------------------------------------------------------------
//
// HookDrive
//
// Hook the drive specified by determining which device object to 
// attach to. The algorithm used here is similar to the one used
// internally by NT to determine which device object a file system request
// is directed at.
//
//----------------------------------------------------------------------
BOOLEAN 
HookDrive( 
    IN ULONG Drive, 
    IN PDRIVER_OBJECT DriverObject 
    )
{
    IO_STATUS_BLOCK     ioStatus;
    HANDLE              ntFileHandle;   
    OBJECT_ATTRIBUTES   objectAttributes;
    PDEVICE_OBJECT      fileSysDevice;
    PDEVICE_OBJECT      hookDevice;
    UNICODE_STRING      fileNameUnicodeString;
    PFILE_FS_ATTRIBUTE_INFORMATION fileFsAttributes;
    ULONG               fileFsAttributesSize;
    WCHAR               filename[] = L"\\DosDevices\\A:\\";
    NTSTATUS            ntStatus;
    ULONG               i;
    PFILE_OBJECT        fileObject;
    PHOOK_EXTENSION     hookExtension;
    
    //
    // Is it a legal drive letter?
    //
    if( Drive >= 26 )  {

        return FALSE;
    }

    //
    // Has this drive already been hooked?
    //
    if( DriveHookDevices[Drive] == NULL )  {

        //
        // Frob the name to make it refer to the drive specified in the input 
        // parameter.
        //
        filename[12] = (CHAR) ('A'+Drive);

        //
        // We have to figure out what device to hook - first open the volume's 
        // root directory
        //
        RtlInitUnicodeString( &fileNameUnicodeString, filename );
        InitializeObjectAttributes( &objectAttributes, &fileNameUnicodeString, 
                                    OBJ_CASE_INSENSITIVE, NULL, NULL );
        ntStatus = ZwCreateFile( &ntFileHandle, SYNCHRONIZE|FILE_ANY_ACCESS, 
                                 &objectAttributes, &ioStatus, NULL, 0, FILE_SHARE_READ|FILE_SHARE_WRITE, 
                                 FILE_OPEN, 
                                 FILE_SYNCHRONOUS_IO_NONALERT|FILE_DIRECTORY_FILE, 
                                 NULL, 0 );
        if( !NT_SUCCESS( ntStatus ) ) {

            DbgPrint(("Filemon: Could not open drive %c: %x\n", 'A'+Drive, ntStatus ));
            return FALSE;
        }

        DbgPrint(("Filemon:  opened the root directory!!! handle: %x\n", ntFileHandle));   

        //
        // Got the file handle, so now look-up the file-object it refers to
        //
        ntStatus = ObReferenceObjectByHandle( ntFileHandle, FILE_READ_DATA, 
                                              NULL, KernelMode, &fileObject, NULL );
        if( !NT_SUCCESS( ntStatus )) {

            DbgPrint(("Filemon: Could not get fileobject from handle: %c\n", 'A'+Drive ));
            ZwClose( ntFileHandle );
            return FALSE;
        }

        //  
        // Next, find out what device is associated with the file object by getting its related
        // device object
        //
        fileSysDevice = IoGetRelatedDeviceObject( fileObject );

        if( ! fileSysDevice ) {

            DbgPrint(("Filemon: Could not get related device object: %c\n", 'A'+Drive ));
            ObDereferenceObject( fileObject );
            ZwClose( ntFileHandle );
            return FALSE;
        }

        //  
        // Check the device list to see if we've already attached to this particular device. 
        // This can happen when more than one drive letter is being handled by the same network
        // redirecter
        //  
        for( i = 0; i < 26; i++ ) {

            if( DriveHookDevices[i] == fileSysDevice ) {

                //
                // If we're already watching it, associate this drive letter
                // with the others that are handled by the same network driver. This
                // enables us to intelligently update the hooking menus when the user
                // specifies that one of the group should not be watched -we mark all
                // of the related drives as unwatched as well
                //
                ObDereferenceObject( fileObject );
                ZwClose( ntFileHandle );
                DriveHookDevices[ Drive ] = fileSysDevice;
                return TRUE;
            }
        }

        //
        // The file system's device hasn't been hooked already, so make a hooking device
        //  object that will be attached to it.
        //
        ntStatus = IoCreateDevice( DriverObject,
                                   sizeof(HOOK_EXTENSION),
             

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色综合久久99| 亚洲婷婷在线视频| 日韩精品中文字幕在线一区| 欧美精品少妇一区二区三区| 日本丶国产丶欧美色综合| 91丨九色丨蝌蚪丨老版| 99综合电影在线视频| 成年人国产精品| av在线不卡电影| 91美女片黄在线观看| 色悠悠久久综合| 91福利区一区二区三区| 欧美亚洲禁片免费| 51午夜精品国产| 亚洲精品一区二区三区精华液| 亚洲精品一线二线三线| 国产人久久人人人人爽| 国产精品久久久久久一区二区三区 | 成人伦理片在线| 99久久精品国产网站| 91老司机福利 在线| 欧美性猛交xxxxxx富婆| 欧美肥大bbwbbw高潮| 精品国精品国产| 国产精品久久久久天堂| 亚洲国产wwwccc36天堂| 奇米色777欧美一区二区| 九九九精品视频| 丁香婷婷深情五月亚洲| 91蜜桃在线观看| 欧美一区二区在线观看| 久久女同性恋中文字幕| 国产精品久久二区二区| 亚洲综合激情网| 久久99九九99精品| 99国产精品久久久| 在线播放中文一区| 久久精品视频免费| 亚洲午夜久久久久久久久电影院| 日韩av一区二区三区四区| 国产乱理伦片在线观看夜一区| 91麻豆视频网站| 51午夜精品国产| 中文字幕中文字幕在线一区| 亚洲国产视频一区二区| 国产在线观看免费一区| 91理论电影在线观看| 精品黑人一区二区三区久久| 最近日韩中文字幕| 日本aⅴ精品一区二区三区| www.久久久久久久久| 在线播放欧美女士性生活| 国产精品久久久久久久久免费樱桃| 亚洲图片自拍偷拍| 风间由美一区二区三区在线观看 | 亚洲视频香蕉人妖| 久久99精品国产麻豆婷婷洗澡| 老司机免费视频一区二区三区| 欧美激情在线一区二区三区| 一区av在线播放| 国产在线国偷精品免费看| 91黄视频在线| 2020国产成人综合网| 一区二区三区高清在线| 激情综合网av| 欧美吞精做爰啪啪高潮| 国产日韩成人精品| 首页国产欧美日韩丝袜| www.欧美色图| 久久久蜜桃精品| 日韩激情一二三区| 日本精品视频一区二区| 中文字幕乱码亚洲精品一区| 免费观看在线综合| 欧美午夜片在线观看| 中文av字幕一区| 日本sm残虐另类| 欧美视频精品在线| 中文字幕一区二| 国产精品一区在线| 日韩免费成人网| 午夜精品福利一区二区三区蜜桃| www.欧美日韩| 亚洲国产精品高清| 国产一区 二区| 欧美一级黄色大片| 亚洲成人在线免费| 色噜噜偷拍精品综合在线| 国产精品免费看片| 国产99精品在线观看| 欧美精品一区二区三区在线播放| 爽好久久久欧美精品| 欧美视频精品在线观看| 一区二区三区免费在线观看| eeuss鲁片一区二区三区在线观看| 久久五月婷婷丁香社区| 久久精品国产成人一区二区三区| 欧美日韩国产小视频在线观看| 亚洲人精品一区| 99久久伊人网影院| 国产精品毛片a∨一区二区三区| 国产一区美女在线| 国产三级一区二区| 国产91精品欧美| 久久久久国色av免费看影院| 久久国产视频网| 久久久久综合网| 粉嫩av一区二区三区| 国产精品视频yy9299一区| 成人午夜激情片| 亚洲男同1069视频| 色av成人天堂桃色av| 一级日本不卡的影视| 欧美日韩一本到| 蜜臀精品一区二区三区在线观看 | 亚洲激情自拍偷拍| 欧美综合天天夜夜久久| 亚洲电影视频在线| 91精品福利在线一区二区三区| 免费不卡在线观看| 国产亚洲成aⅴ人片在线观看| 成人激情免费视频| 亚洲欧美国产三级| 欧美日韩精品一区视频| 美女在线视频一区| 国产亚洲精品aa| www.欧美日韩国产在线| 亚洲亚洲精品在线观看| 日韩欧美色综合网站| 懂色av一区二区三区蜜臀| 亚洲日本在线观看| 欧美日韩国产美| 精品亚洲国产成人av制服丝袜| 日本一区二区三区四区在线视频 | 亚洲品质自拍视频| 欧美日韩精品一区二区在线播放| 免费看黄色91| 亚洲国产经典视频| 欧美性受极品xxxx喷水| 久久精品国产第一区二区三区| 中文字幕免费观看一区| 欧美在线高清视频| 国产一区二区在线看| 国产精品国产三级国产| 欧美精选在线播放| 国产精品一区二区在线播放| 亚洲欧美国产三级| 日韩免费视频一区二区| 99re8在线精品视频免费播放| 亚洲3atv精品一区二区三区| 久久午夜国产精品| 欧美亚洲高清一区二区三区不卡| 精品一区二区三区免费观看 | 精品一二三四在线| 亚洲欧美日韩国产综合| 日韩久久久久久| 91视视频在线观看入口直接观看www| 亚洲va韩国va欧美va精品| 国产女人18水真多18精品一级做| 欧洲激情一区二区| 成人免费毛片aaaaa**| 午夜精品福利在线| 亚洲欧美日韩国产综合在线| 精品区一区二区| 欧美亚洲尤物久久| 白白色 亚洲乱淫| 经典三级在线一区| 日韩精品亚洲专区| 亚洲视频一区在线| 国产午夜三级一区二区三| 欧美精品丝袜中出| 91蜜桃在线免费视频| 国产成人免费av在线| 日韩福利视频网| 一区二区三区四区乱视频| 国产欧美精品日韩区二区麻豆天美| 欧美一级精品大片| 欧美日韩在线电影| 97久久精品人人澡人人爽| 国产真实精品久久二三区| 日韩av一级电影| 亚洲国产精品久久人人爱蜜臀| 国产精品超碰97尤物18| 国产亚洲精久久久久久| 欧美v日韩v国产v| 日韩午夜精品电影| 欧美日本乱大交xxxxx| 色婷婷狠狠综合| 成人黄色在线网站| 成人午夜又粗又硬又大| 精东粉嫩av免费一区二区三区| 日本欧美一区二区三区乱码| 亚洲制服欧美中文字幕中文字幕| 中文字幕一区二区三区蜜月| 国产拍欧美日韩视频二区| 久久精品欧美一区二区三区不卡| 精品国产乱码久久久久久夜甘婷婷| 91麻豆精品91久久久久久清纯| 在线免费观看日本一区| 色婷婷av一区|