• <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>

            小默

            發送IRP刪除正在運行文件學習筆記zz

            在網上看到了北極星2003寫的這篇文章,代碼寫的很好,注釋也很清楚,方便了我這個大菜鳥的學習,對他的無私奉獻非常非常感謝。

            強制刪除文件的思路就是,把SECTION_OBJECT_POINTERS結構的DataSectionObjectImageSectionObject兩個域清空即可刪除正在運行的文件。如果不清空就不能刪除運行中的文件。正在運行的文件的這兩個域值不為0而文件系統正在根據這兩個域決定該文件是否可以刪除。如果文件系統檢測這兩個值為0,就理解為文件沒有被使用,可以刪除。接下去,就是直接發IRP,初始化IRP,設置IRP堆棧信息,設置完成例程,派發IRP。

            一、獲得文件內核句柄

            RtlInitUnicodeString ( &FileName, L” \\DosDevices\\C:\\test.exe” ) ;

            InitializeObjectAttributes ( &objectAttributes, &FileName,\

            OBJ_KERNEL_HANDLE|OBJ_CASE_INSENSITIVE, \

            NULL, NULL ) ;  

            ntStatus = IoCreateFile ( &hFile,FILE_READ_ATTRIBUTES, &objectAttributes, &ioStatus, \

                          0,FILE_ATTRIBUTE_NORMAL,FILE_SHARE_DELETE,FILE_OPEN,0,NULL,0,\

            CreateFileTypeNone,NULL, IO_NO_PARAMETER_CHECKING);

            打開文件應該傳入這個文件的路徑。但是實際上這個函數IoCreateFile并不直接接受一個字符串。使用者必須首先填寫一個OBJECT_ATTRIBUTES 結構。

            用到一個宏:InitializeObjectAttributes用來初始化對象屬性

            我們是對c:\test.exe,這是個固定的文件了,屬性應該也固定了,為什么還要初始化屬性呢?

            其實這里的初始化屬性,主要是為了包含文件的對象路徑,然后在指明該代碼對該文件的一些要求,如獲得內核句柄,不區分文件名的大小寫,而不是對文件的操作。即將FileName,OBJ_KERNEL_HANDLE|OBJ_CASE_INSENSITIVE,全放入objectAttributes這個結構中。

            typedef struct _OBJECT_ATTRIBUTES {

                ULONG Length;

                HANDLE RootDirectory;

                PUNICODE_STRING ObjectName;

                ULONG Attributes;

                PVOID SecurityDescriptor;

                PVOID SecurityQualityOfService;

            } OBJECT_ATTRIBUTES, *POBJECT_ATTRIBUTES;

            要說明2點:

            1objectAttributes結構中的ObjectName要求的是對象的路徑名,因此不能寫成c:\test,

            c:是一個符號鏈接對象,內核模式下,符號鏈接要寫成\\??\\C:或者\\DosDevices\\C:

            因此對象路徑名為:\\DosDevices\\C:\\test.exe\\??\\C:\\test.exe

            2InitializeObjectAttributes 只需要填寫OBJ_CASE_INSENSITIVE| OBJ_KERNEL_HANDLE即可

            OBJ_CASE_INSENSITIVE意味著名字字符串是 不區分大小寫的

            OBJ_KERNEL_HANDLE表明打開的文件句柄一個“內核句柄”

            二、發送IRP去除文件的只讀屬性

            對文件的任何操作,最終都是通過IRP請求,然后文件系統驅動對該IRP進行處理,完成對文件的指定操作。

            驅動程序,則可以自己創建IRP,初始化IRP,設置IRP堆棧信息,設置完成例程,派發IRP。這里我們采用的就是這種方法。

            三、發送IRP刪除文件

            Windows API中的DeleteFile實現文件刪除功能的內部實現:

            DeleteFile 通過 IRP_MJ_SET_INFORMATION請求的IRP,并且將pIrpStack->Parameters.SetFile.FileInformationClass設為FileDispositionInformation((PFILE_DISPOSITION_INFORMATION)Irp->AssociatedIrp.SystemBuffer)->DeleteFile設為TRUE來達到刪除文件。

            所以我們有:

            FILE_DISPOSITION_INFORMATION    FileInformation;

            FileInformation.DeleteFile = TRUE;

            // 初始化IRP  

            Irp->AssociatedIrp.SystemBuffer          = &FileInformation;  

            // 設置IRP堆棧  

            irpSp->Parameters.SetFile.FileInformationClass   = FileDispositionInformation;

            由上,我們可以刪除這個文件,但是如果文件在運行,則不能刪除,需要加上如下代碼:

            // 如果沒有這4行,就無法刪除正在運行的文件  

            PSECTION_OBJECT_POINTERS        pSectionObjectPointer;

                pSectionObjectPointer = fileObject->SectionObjectPointer;  

                pSectionObjectPointer->ImageSectionObject = 0;  

                pSectionObjectPointer->DataSectionObject = 0;  

            對于如何創建IRP,初始化IRP,設置IRP堆棧信息,設置完成例程,派發IRP,這里先不寫了,等再整理整理后再寫吧。

            posted on 2010-02-06 00:18 小默 閱讀(1195) 評論(0)  編輯 收藏 引用 所屬分類: Windows

            導航

            統計

            留言簿(13)

            隨筆分類(287)

            隨筆檔案(289)

            漏洞

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            久久国产热这里只有精品| 97久久婷婷五月综合色d啪蜜芽 | 99久久国语露脸精品国产| 久久精品国产亚洲AV大全| 99国产欧美久久久精品蜜芽| 日本福利片国产午夜久久| 久久婷婷色综合一区二区| 久久久亚洲AV波多野结衣| 久久精品国产一区| 亚洲欧美成人久久综合中文网| 国产成人久久精品一区二区三区 | 无码人妻久久一区二区三区蜜桃| 欧美日韩精品久久久免费观看| 久久久精品人妻一区二区三区蜜桃| 久久亚洲精品中文字幕三区| 国产精品亚洲综合久久| 久久久久久久综合日本亚洲| 久久人人爽人人人人片av| 国产精品九九久久精品女同亚洲欧美日韩综合区 | 浪潮AV色综合久久天堂| 久久精品夜色噜噜亚洲A∨| 精品无码久久久久久尤物| 噜噜噜色噜噜噜久久| yellow中文字幕久久网| 久久w5ww成w人免费| 18岁日韩内射颜射午夜久久成人| 人妻精品久久久久中文字幕| 久久www免费人成看国产片| 久久综合中文字幕| 精品综合久久久久久888蜜芽| 久久这里只有精品首页| 香蕉久久夜色精品国产尤物| 久久久WWW免费人成精品| 91久久精品国产成人久久| 久久99国产精品尤物| 五月丁香综合激情六月久久| 一本一本久久A久久综合精品| 97视频久久久| 人人狠狠综合久久88成人| 久久精品亚洲日本波多野结衣| 欧美va久久久噜噜噜久久|