《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > 基于Windows的磁盤數據清除技術
基于Windows的磁盤數據清除技術
電子技術
何 娜,趙亦工,江 華
摘要: 在研究Windows操作系統中文件管理系統NTFS的基礎上,提出一種徹底清除磁盤數據的方法。NTFS對文件的訪問操作,主要通過與文件相關的MFT表進行,這與FAT系統存在較大差異。通過分析MFT表管理磁盤數據的方法,建立一種樹形目錄結構,并以該樹形目錄作為管理磁盤中所有MFT表的工具。采用遍歷之后立即釋放樹結點的方法,解決了內存過度占用的問題。該技術可以在磁盤扇區直接清除數據,還可對數據進行更加直接的管理,減少了對操作系統的
Abstract:
Key words :

安全的磁盤清理軟件可以很好地為數字化信息系統服務。目前大部分磁盤清理軟件未能徹底清除在磁盤中的數據,對于磁盤上已經刪除的文件信息在未重新寫入新的文件時,Windows只是標記,并沒有進行數據清理。這就使得可以通過數據恢復的手段獲取保密信息,大多數清理軟件只是采用重新填寫無效文件的方式清除磁盤上的數據。而這樣會大大縮短磁盤的使用壽命。文中研究了Windows的文件系統NTFS清除磁盤數據的原理,采用直接訪問NTFS的主文件列表找到文件具體存儲的位置,并解碼二進制文件,從而徹底清除文件,減少了對操作系統的依賴,避免了大量盲目填寫無效文件的操作,并保護了磁盤使用壽命。

1 NTFS系統結構原理
1.1 基本原理
NTFS是Windows NT引入的新型文件系統,由于NTFS的結構復雜,內容繁多,這里僅對NTFS卷上的底層結構做分析。在NTFS格式中,文件以簇的形式分配。最小的單位為扇區,N個扇區為一簇。其中,N的值由引導扇區規定。NTFS格式磁盤的數據分為4大部分:引導區、主文件列表、系統文件和文件數據區。
引導區(Partition boot sector):所有磁盤格式都有這個區,占用了磁盤第一個扇區。
主文件列表(Master File List):記錄了卷上所有文件,每個文件對應了表上的一條記錄。
系統文件(System file):NTFS一共有16個系統文件,8個隱藏文件。
文件數據區(File Area):存放文件數據。
NTFS跟FAT16,FA332一樣都在引導扇區中有一些BPB參數,但與FAT32,FAT16并不完全相同。文獻對NTFS引導扇區一些重要數據的含義進行了詳細介紹。
1.2 主控文件表與元數據文件
MFT是一個對應的數據庫,由一系列的文件記錄組成,卷中每一個文件都有一個文件記錄。主文件表本身也有自己的文件記錄。實際上,MFT自身也是一個文件,因此,主文件列表的第一個記錄就是它自身。MFT的每個記錄都有一個編號,這里稱為ID號,這個ID從0開始。MFT自身是NTFS系統的第一個文件,所以文件$MFT的ID號為0。
MFT和其他23個文件一起,用戶每添加一個文件ID號加1。MFT頭的長度跟偏移處的數據含義不變,但屬性列表是可變的,其不同的屬性列表,有著不同的含義,最后能看到MFT表以FFFFFFFFH結束。
MFT頭的標準信息見文獻,它對MFT表的結構進行了全面的分析。MFT前16個文件屬于系統文件,也稱為元文件,用于存放系統中的元數據,元數據文件及其作用見文獻。
1.3 文件的MFT記錄及其包含的屬性
一個文件通常占用一條文件記錄。然而當一個文件具有多項屬性值的時候,就可以占用一個以上的文件記錄。這樣的情況下,第一個文件記錄就是基本文件記錄。其中存儲了該文件需要其他文件記錄的位置。小文件和小的文件夾將全部存放在MFT記錄中。
文件記錄包含索引信息,小的文件夾記錄完全存儲在MFT結構里。然而大文件與文件夾被組織成為B+樹結構,一個指針指向一個外部簇,該簇用來存放那些MFT內存儲不了的文件夾屬性。
在MFT記錄中的每個屬性都有一個屬性頭,這個屬性頭包含一些該屬性的重要信息,如屬性類型、大小、名字以及是否為常駐屬性等。

2 具體實現方法
具體實現分為兩個模塊:(1)索引磁盤中所有文件的數據段在磁盤中存放的起始簇號。(2)動態建立一個與磁盤文件存放相對的文件樹,對子樹進行遍歷查找每個文件數據段的簇號,從而可以從扇區直接清除數據信息。最后刪除所建立的子樹,釋放占據的內存空間。
2.1 索引磁盤中未刪除文件的簇號
在NTFS中,文件目錄僅是文件名的一個索引,NTFS使用了一種特殊的方式把文件名組織起來,以便快速訪問。當創建一個目錄時,NTFS必須對目錄中的文件名屬性進行索引。

一個目錄的MFT將其目錄中的文件名與子目錄名進行排序,并保存在索引根屬性中。所以可以通過訪問根目錄的索引分配找到磁盤上面的一級目錄,并記錄下其MFT參考號,然后在通過該參考號獲取MFT文件,進而再找到其索引分配,就可以將一級目錄下的子目錄全部及找到,直到不再有子目錄為止。可建立出整個磁盤的目錄樹,每項MFT文件中都記錄了該文件是被刪除或正在被使用的目錄。通過解析以上分析的屬性就能獲取這些信息,該算法流程如圖1所示。

c.JPG


圖中每一步操作都是根據MFT表的屬性進行編碼。
第一步從分區信息表即中可以獲得這些有用的信息。讀取特定扇區的信息可以調用CreateFile與ReadFile來實現。讀取某個MFT元文件的具體方法是:通過BPB參數獲取$MFT的位置,然后根據源文件的MFT記錄號,移動句柄,就可以順利讀取MFT元文件。由于每個MFT文件的大小是1 kB,所以句柄的偏移dwStartSector=MFT文件記錄號×2+$MFT所在的扇區號。即可訪問任何一個磁盤的MFT元數據文件信息。
第二步根據根目錄的MFT文件信息,解析索引A0H屬性從而找出索引信息,這涉及到解碼二進制文件。
第三步根據索引中的信息找出根目錄的子目錄的MFT編號,再根據這個編號打開MFT文件內容,找出30H屬性與MFT屬性頭,解析文件名,以及標記文件是否為目錄,是否被刪除的信息。
第四步如果該文件是目錄,則繼續查找它下面的子目錄,否則轉第五步。
第五步 如果該文件已刪除,則返回第一步;否則,打開它對應的MFT文件,然后解析80H屬性,找到文件數據段開始的簇號,并記錄下來。
2.2 建立磁盤對應的文件樹
建立一個N叉樹來表示每一個磁盤中的文件存放,只是它的數據信息就是上面獲取的文件數據段開始的簇的編號。遍歷文件樹的過程,即是獲取簇號以及對相應簇的信息進行清除的過程。每個磁盤中MFT表的數量巨大,所以在遍歷完根目錄下子目錄的所有文件時,要刪除該子樹,便于釋放內存,從而減少算法的空間開銷。而且N叉樹的數據結構本身對遍歷效率也有很大提升,筆者采用深度優先遞歸搜索,并對此進行優化,取得了良好效果。

測試平臺為windows7,測試工具為winhex。清除之前可以看到新建文本文檔大小是6.9 kB,所在簇的信息如圖2所示。

a.JPG

b.JPG


執行程序后結果如圖3所示。可以看到文件的大小歸0,并且80H的信息發生變化,原本存儲的索引內容全部被清除為0,即文件的數據信息全部被清除。

3 結束語
NTFS文件系統十分復雜,這里主要針對NTFS系統管理磁盤的MFT文件進行分析,解析它的一系列屬性,得到每個文件的數據段信息的開始簇號。通過對磁盤建立文件樹,標記所有未刪除文件的數據段開始的簇號,從而可以直接清除剩余磁盤簇的信息,達到繞過操作系統直接對扇區進行清除的目的,避免了數據恢復的可能。

此內容為AET網站原創,未經授權禁止轉載。
主站蜘蛛池模板: 亚洲欧美日韩中文在线 | 青春久草 | 午夜大片在线观看 | 韩国伦理片免费观看 | 大学生一级毛片全黄毛片黄 | 国产又色又爽又黄 | 国产成人8x视频一区二区 | 综合网插 | 日日艹| 亚洲国产激情 | 手机午夜视频 | 国产dvd毛片在线视频 | 成人在线午夜 | 久久国产精品永久免费网站 | 色在线视频观看 | 欧美视频精品在线观看 | 三级黄色片免费观看 | 激情影院网站 | 欧美日本高清视频在线观看 | 欧美伊人久久大香线蕉在观 | 女性爽爽影院免费观看麻豆 | 二级毛片免费观看全程 | 午夜视频在线观看视频 | 手机免费看伦理片 | 香蕉午夜视频 | 亚洲国产片在线观看 | 国产精品香蕉成人网在线观看 | 免费视频亚洲 | 成人在线视频网 | 精品久久天干天天天按摩 | 一级黄色大片免费看 | 欧洲视频一区 | 国产日韩综合 | 亚洲五月激情网 | 欧美成人性生活片 | 二区三区不卡不卡视频 | 黄色小视频在线观看免费 | 亚洲成人综合在线 | 精品欧美 | 一级黄色一级片 | 亚洲欧洲日韩综合色天使不卡 |