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

小默

發(fā)送IRP刪除正在運(yùn)行文件學(xué)習(xí)筆記zz

在網(wǎng)上看到了北極星2003寫的這篇文章,代碼寫的很好,注釋也很清楚,方便了我這個(gè)大菜鳥(niǎo)的學(xué)習(xí),對(duì)他的無(wú)私奉獻(xiàn)非常非常感謝。

強(qiáng)制刪除文件的思路就是,把SECTION_OBJECT_POINTERS結(jié)構(gòu)的DataSectionObjectImageSectionObject兩個(gè)域清空即可刪除正在運(yùn)行的文件。如果不清空就不能刪除運(yùn)行中的文件。正在運(yùn)行的文件的這兩個(gè)域值不為0而文件系統(tǒng)正在根據(jù)這兩個(gè)域決定該文件是否可以刪除。如果文件系統(tǒng)檢測(cè)這兩個(gè)值為0,就理解為文件沒(méi)有被使用,可以刪除。接下去,就是直接發(fā)IRP,初始化IRP,設(shè)置IRP堆棧信息,設(shè)置完成例程,派發(fā)IRP

一、獲得文件內(nèi)核句柄

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);

打開(kāi)文件應(yīng)該傳入這個(gè)文件的路徑。但是實(shí)際上這個(gè)函數(shù)IoCreateFile并不直接接受一個(gè)字符串。使用者必須首先填寫一個(gè)OBJECT_ATTRIBUTES 結(jié)構(gòu)。

用到一個(gè)宏:InitializeObjectAttributes用來(lái)初始化對(duì)象屬性

我們是對(duì)c:\test.exe,這是個(gè)固定的文件了,屬性應(yīng)該也固定了,為什么還要初始化屬性呢?

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

typedef struct _OBJECT_ATTRIBUTES {

    ULONG Length;

    HANDLE RootDirectory;

    PUNICODE_STRING ObjectName;

    ULONG Attributes;

    PVOID SecurityDescriptor;

    PVOID SecurityQualityOfService;

} OBJECT_ATTRIBUTES, *POBJECT_ATTRIBUTES;

要說(shuō)明2點(diǎn):

1objectAttributes結(jié)構(gòu)中的ObjectName要求的是對(duì)象的路徑名,因此不能寫成c:\test,

c:是一個(gè)符號(hào)鏈接對(duì)象,內(nèi)核模式下,符號(hào)鏈接要寫成\\??\\C:或者\\DosDevices\\C:

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

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

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

OBJ_KERNEL_HANDLE表明打開(kāi)的文件句柄一個(gè)“內(nèi)核句柄”

二、發(fā)送IRP去除文件的只讀屬性

對(duì)文件的任何操作,最終都是通過(guò)IRP請(qǐng)求,然后文件系統(tǒng)驅(qū)動(dòng)對(duì)該IRP進(jìn)行處理,完成對(duì)文件的指定操作。

驅(qū)動(dòng)程序,則可以自己創(chuàng)建IRP,初始化IRP,設(shè)置IRP堆棧信息,設(shè)置完成例程,派發(fā)IRP。這里我們采用的就是這種方法。

三、發(fā)送IRP刪除文件

Windows API中的DeleteFile實(shí)現(xiàn)文件刪除功能的內(nèi)部實(shí)現(xiàn):

DeleteFile 通過(guò) IRP_MJ_SET_INFORMATION請(qǐng)求的IRP,并且將pIrpStack->Parameters.SetFile.FileInformationClass設(shè)為FileDispositionInformation((PFILE_DISPOSITION_INFORMATION)Irp->AssociatedIrp.SystemBuffer)->DeleteFile設(shè)為TRUE來(lái)達(dá)到刪除文件。

所以我們有:

FILE_DISPOSITION_INFORMATION    FileInformation;

FileInformation.DeleteFile = TRUE;

// 初始化IRP  

Irp->AssociatedIrp.SystemBuffer          = &FileInformation;  

// 設(shè)置IRP堆棧  

irpSp->Parameters.SetFile.FileInformationClass   = FileDispositionInformation;

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

// 如果沒(méi)有這4行,就無(wú)法刪除正在運(yùn)行的文件  

PSECTION_OBJECT_POINTERS        pSectionObjectPointer;

    pSectionObjectPointer = fileObject->SectionObjectPointer;  

    pSectionObjectPointer->ImageSectionObject = 0;  

    pSectionObjectPointer->DataSectionObject = 0;  

對(duì)于如何創(chuàng)建IRP,初始化IRP,設(shè)置IRP堆棧信息,設(shè)置完成例程,派發(fā)IRP,這里先不寫了,等再整理整理后再寫吧。

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

導(dǎo)航

統(tǒng)計(jì)

留言簿(13)

隨筆分類(287)

隨筆檔案(289)

漏洞

搜索

積分與排名

最新評(píng)論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            女主播福利一区| 亚洲国产人成综合网站| 免费成人你懂的| 欧美成人嫩草网站| 性做久久久久久久久| 欧美影视一区| 午夜天堂精品久久久久| 亚洲国产精品久久久久秋霞影院 | 亚洲小说欧美另类婷婷| 狠狠色综合网| 艳女tv在线观看国产一区| 国产亚洲欧美激情| 亚洲免费观看高清完整版在线观看熊 | 国产精品卡一卡二卡三| 欧美成人性网| 国产欧美日韩免费| 亚洲精品乱码久久久久久黑人| 国产精品一区二区久久精品| 亚洲大片精品永久免费| 国产真实精品久久二三区| 日韩视频在线一区二区| 亚洲国产精品一区| 欧美一站二站| 性高湖久久久久久久久| 欧美视频一区二区三区四区| 欧美激情精品久久久久久蜜臀| 国产欧美视频一区二区| 一区二区三区av| 日韩午夜免费| 亚洲欧美日韩国产| 久久久女女女女999久久| 欧美日韩在线播放| 亚洲国产免费| 亚洲国语精品自产拍在线观看| 久久精品国产亚洲a| 欧美一区二区性| 国产精品久久久久久久久果冻传媒| 亚洲激情在线激情| 亚洲人成啪啪网站| 欧美成人激情视频| 亚洲国产一区二区三区a毛片| 在线观看的日韩av| 久久综合久久久久88| 久久视频在线视频| 在线精品福利| 久久欧美肥婆一二区| 久久影院亚洲| 136国产福利精品导航网址应用| 久久久久久久久久久久久9999| 久久亚洲视频| 亚洲国产视频a| 欧美jizz19性欧美| 亚洲欧洲偷拍精品| 亚洲午夜精品一区二区| 国产精品久久久久久久久免费桃花| 中文亚洲字幕| 久久精品水蜜桃av综合天堂| 国产一区二区三区网站 | 亚洲毛片av在线| 亚洲电影免费观看高清完整版在线观看 | 久久国产天堂福利天堂| 久久综合成人精品亚洲另类欧美| 久久久国产精品亚洲一区| 精品99一区二区| 久久久久一区二区| 亚洲国产老妈| 99这里只有久久精品视频| 欧美午夜www高清视频| 亚洲午夜视频在线观看| 久久久久国产成人精品亚洲午夜| 一区二区三区在线视频播放| 噜噜噜躁狠狠躁狠狠精品视频| 欧美成人午夜剧场免费观看| 中文一区二区| 国产亚洲日本欧美韩国| 免费成人高清在线视频| 一本大道av伊人久久综合| 久久国产精品一区二区| 亚洲国产天堂久久综合| 欧美视频免费在线| 欧美在线视频免费| 91久久亚洲| 久久精品九九| 亚洲人午夜精品免费| 国产精品久久久久婷婷| 久久精品主播| 一区二区三区高清在线| 噜噜噜91成人网| 久久久久久免费| 激情久久久久久| 欧美日韩亚洲一区二区| 久久精品国产久精国产爱| 亚洲精品久久久久久下一站| 久久久精品一品道一区| 一区二区三区欧美激情| 精品999成人| 国产精品日本精品| 欧美黄色视屏| 久久久久.com| 亚洲欧美日产图| 亚洲日本国产| 欧美wwwwww| 香蕉免费一区二区三区在线观看| 亚洲日本中文字幕| 韩国精品在线观看| 国产精品乱码| 欧美日韩视频在线观看一区二区三区| 性久久久久久久久| 一本色道久久综合精品竹菊 | 欧美性生交xxxxx久久久| 久久精品一区二区三区不卡| 亚洲视频在线观看免费| 亚洲精品国精品久久99热一| 女生裸体视频一区二区三区| 久久激情网站| 欧美一区二区三区男人的天堂| 99视频一区| 亚洲人成在线免费观看| 在线观看一区视频| 国产综合18久久久久久| 蜜臀av性久久久久蜜臀aⅴ四虎| 欧美日韩亚洲国产精品| 欧美国产日本| 欧美成人首页| 美女福利精品视频| 久久人人97超碰国产公开结果| 性久久久久久| 先锋影音一区二区三区| 午夜精品一区二区三区四区| 亚洲靠逼com| 日韩视频精品在线观看| 日韩一级精品视频在线观看| 亚洲精品视频在线播放| 亚洲人成在线观看一区二区| 国产婷婷精品| 亚洲另类视频| 国产亚洲一区二区三区| 国产日韩精品一区二区浪潮av| 国产精品久久97| 国产精品免费网站| 国产精品久久久久久久久久久久 | 久久精品综合一区| 欧美一区二区在线观看| 欧美一区二区三区精品电影| 先锋影音一区二区三区| 欧美在线视频免费| 久久人人爽人人| 欧美第一黄网免费网站| 欧美国产一区二区在线观看| 最新中文字幕一区二区三区| 91久久在线播放| 99av国产精品欲麻豆| 亚洲新中文字幕| 久久精品国产99国产精品澳门| 久久久美女艺术照精彩视频福利播放| 一区二区精品在线观看| 久久裸体艺术| 欧美激情一区二区三区在线视频观看| 欧美人与性动交α欧美精品济南到| 欧美激情视频在线免费观看 欧美视频免费一 | 在线观看亚洲视频啊啊啊啊| 在线日韩欧美| 一本到12不卡视频在线dvd| 一区二区三区四区国产| 亚洲欧美日韩爽爽影院| 久久婷婷人人澡人人喊人人爽| 欧美ed2k| 亚洲天堂黄色| 久久久久久9999| 欧美二区在线观看| 欧美午夜精品久久久久久人妖| 国产性做久久久久久| 亚洲黄色天堂| 先锋影音国产一区| 欧美激情亚洲综合一区| 一区二区三区日韩欧美| 久久精品国产一区二区三区| 老司机凹凸av亚洲导航| 欧美日韩一区二区精品| 国产在线精品自拍| 一区二区福利| 美女国产精品| 亚洲小视频在线观看| 牛人盗摄一区二区三区视频| 欧美日韩你懂的| 在线精品视频免费观看| 亚洲欧美日韩直播| 欧美日韩亚洲精品内裤| 久久精品女人的天堂av| 欧美精品一区三区在线观看| 国产亚洲一区二区三区在线观看| 亚洲日韩欧美视频| 久久久久久穴| 宅男66日本亚洲欧美视频| 麻豆精品视频在线| 国产精品一区亚洲| 亚洲色诱最新| 91久久综合亚洲鲁鲁五月天| 欧美有码视频| 国产精品久久毛片a|