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

小默

發送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 小默 閱讀(1211) 評論(0)  編輯 收藏 引用 所屬分類: Windows

導航

統計

留言簿(13)

隨筆分類(287)

隨筆檔案(289)

漏洞

搜索

積分與排名

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            1024成人| 欧美黄色片免费观看| 欧美视频网站| 欧美久色视频| 欧美精品久久一区二区| 欧美日韩久久不卡| 国产精品白丝av嫩草影院| 欧美日韩在线免费| 国产精品成人av性教育| 欧美体内谢she精2性欧美| 国产精品免费福利| 国产主播精品在线| 亚洲精品在线免费| 午夜精品亚洲一区二区三区嫩草| 羞羞答答国产精品www一本| 久久香蕉国产线看观看av| 亚洲国产精品久久91精品| 麻豆av一区二区三区| 亚洲激情电影中文字幕| 亚洲视频一区| 久久精品综合一区| 欧美日韩免费视频| 韩日在线一区| 亚洲免费在线电影| 亚洲成色最大综合在线| 午夜精品久久久久久久久久久久久 | 午夜在线电影亚洲一区| 久久精品国产99国产精品澳门| 玖玖视频精品| 国产模特精品视频久久久久| 亚洲精品少妇30p| 久久久精彩视频| 99re国产精品| 欧美成人有码| 在线看片日韩| 久久久久免费视频| 亚洲男人的天堂在线| 欧美日韩精品一区二区| 亚洲经典自拍| 欧美岛国激情| 久久综合狠狠| 狠狠入ady亚洲精品| 午夜精品电影| 亚洲精品社区| 欧美寡妇偷汉性猛交| 国语对白精品一区二区| 欧美专区在线播放| 午夜在线成人av| 国产精品视频一二三| 欧美电影免费| 伊人影院久久| 久久久久一区二区| 亚洲欧美一区二区三区久久| 欧美日韩美女在线| 制服诱惑一区二区| 亚洲精品一级| 欧美日韩成人在线观看| 91久久精品国产91性色| 欧美丰满少妇xxxbbb| 久久久精品网| 亚洲国产精品尤物yw在线观看| 久久午夜av| 久久久久久久一区| 国产综合久久久久久鬼色| 久久福利资源站| 午夜精品久久| 激情视频一区二区三区| 猛男gaygay欧美视频| 久久天堂av综合合色| 在线精品亚洲一区二区| 欧美岛国激情| 欧美日韩国产在线| 在线一区二区三区做爰视频网站| 亚洲乱码国产乱码精品精天堂 | 亚洲电影免费观看高清| 欧美成人激情视频| 99视频在线精品国自产拍免费观看| 亚洲欧洲另类| 欧美亚洲成人网| 久久精品99久久香蕉国产色戒 | 国产精品视频久久| 久久蜜桃精品| 欧美激情一区二区三区成人| 亚洲图色在线| 久久精品99无色码中文字幕| 亚洲国产一区二区在线| a4yy欧美一区二区三区| 国产一区二区三区在线观看视频 | 在线免费不卡视频| 亚洲精品视频在线看| 国产精品亚洲美女av网站| 久久亚洲色图| 欧美日韩一卡二卡| 久久―日本道色综合久久| 欧美国产先锋| 久久aⅴ乱码一区二区三区| 美女视频黄 久久| 午夜精品国产更新| 麻豆91精品91久久久的内涵| 亚洲男人第一网站| 欧美jizz19性欧美| 欧美在线亚洲| 欧美日韩国产色视频| 91久久精品国产91久久性色tv| 日韩一区二区福利| 1024欧美极品| 午夜精品一区二区三区四区| 日韩亚洲欧美在线观看| 久久成人资源| 亚洲男女自偷自拍图片另类| 免费观看日韩| 久久久久五月天| 国产精品丝袜xxxxxxx| 91久久精品国产| 黄色成人免费网站| 亚洲欧美日韩一区二区| 中文国产成人精品| 欧美va亚洲va国产综合| 久久久综合网| 国产视频欧美视频| 亚洲欧美成人在线| 亚洲午夜精品17c| 欧美精品国产一区| 欧美激情片在线观看| 国语自产偷拍精品视频偷 | 欧美77777| 蜜臀av性久久久久蜜臀aⅴ四虎| 国产精品尤物| 亚洲综合色自拍一区| 亚洲在线观看| 国产精品sss| 亚洲图片你懂的| 亚洲一线二线三线久久久| 欧美日韩精品高清| 一本色道婷婷久久欧美| 一本色道久久综合亚洲精品不| 欧美肥婆bbw| 最新高清无码专区| 一区二区高清| 国产精品成人一区二区艾草| 亚洲最新在线| 午夜精彩国产免费不卡不顿大片| 国产精品另类一区| 午夜国产不卡在线观看视频| 久久成人18免费网站| 国产午夜精品一区二区三区欧美| 一卡二卡3卡四卡高清精品视频| 在线中文字幕日韩| 国产精品久久久久久久免费软件 | 久久久av网站| 精品动漫av| 欧美激情一区二区三区全黄| 日韩视频在线一区| 欧美一区二区日韩一区二区| 黄色成人在线观看| 欧美日韩国产精品自在自线| 亚洲欧美日韩综合一区| 免费成人黄色| 一本久久综合亚洲鲁鲁五月天 | 在线看无码的免费网站| 欧美国产日韩一区| 亚洲视频你懂的| 免费欧美电影| 中国成人在线视频| 国产日韩欧美在线看| 蜜臀99久久精品久久久久久软件| 亚洲激情视频在线观看| 亚洲午夜视频在线观看| 国产一区二区精品久久91| 亚洲精品在线免费观看视频| 亚洲伊人第一页| 激情久久综艺| 欧美色欧美亚洲另类二区| 欧美在线视频网站| 最近中文字幕mv在线一区二区三区四区| 亚洲社区在线观看| 精品成人一区二区| 欧美视频福利| 欧美成人午夜激情在线| 午夜综合激情| 亚洲乱码精品一二三四区日韩在线| 久久日韩粉嫩一区二区三区| 亚洲免费在线视频| 一区二区高清在线| 在线精品国产成人综合| 国产精品综合不卡av| 欧美激情精品久久久久久大尺度| 午夜精品av| 99亚洲一区二区| 免费人成网站在线观看欧美高清| 亚洲欧美日韩国产综合| 亚洲理论电影网| 在线免费观看视频一区| 国产亚洲成年网址在线观看| 国产精品国产成人国产三级| 欧美人在线观看| 欧美激情精品久久久久久变态| 美女脱光内衣内裤视频久久影院| 午夜精品一区二区三区四区 | 国产精品成人aaaaa网站|