分析FAT32內部結構-入門篇-

来源:https://www.cnblogs.com/ryzz/archive/2019/09/21/11562325.html
-Advertisement-
Play Games

FAT32(File Allocation Table)是一種32位的FAT文件系統,微軟在1996年8月發佈。 FAT32的數字32是下麵會講到的FAT中每個表項的長度。 磁碟(硬碟)是數據的載體,而文件系統則是將這些數據以某種合理的結構組織起來方便操作系統的管理。 藉此文分析一下微軟的FAT32 ...


FAT32(File Allocation Table)是一種32位的FAT文件系統,微軟在19968月發佈。

FAT32的數字32是下麵會講到的FAT中每個表項的長度。

磁碟(硬碟)是數據的載體,而文件系統則是將這些數據以某種合理的結構組織起來方便操作系統的管理。

藉此文分析一下微軟的FAT32文件系統格式:(本文分析的FAT32分區是D盤,大小為128MB!環境為VMware虛擬機下的XP系統!

FAT324個部分組成,分別是DBR,FAT1,FAT2DATA,如圖:

 

DBR:該分區的引導程式,在DBR的結尾部分會有一些重要的保留扇區(這些保留扇區屬於DBR,圖中未畫出)

FAT1FAT的首要文件分配表

FAT2:文件分配表的備份

DATA:數據區(最小單位為簇(cluster),一般2個扇區為1簇,是微軟規定的一種磁碟存儲單位,與Linuxblock概念類似)

 

FAT32DBR結構圖:

 

紅色:跳轉指令,將當前執行流程跳轉到引導程式處,占2位元組,對應彙編JUMP 58H; NOP;

藍色:OEM代號,由創建該文件系統的廠商規定,占8位元組,一般為”MSDOS5.0”

綠色:BPB(BIOS Paramter Block),從DBR的第12個位元組開始共占用79位元組,記錄了文件系統的重要信息,相關欄位參數見下表

粉紅色:DBR引導程式,如果該分區沒安裝操作系統那麼這段程式是沒用的

黃色:DBR結束標記

BPB表:

偏移

位元組

含義

BH

2

每扇區的位元組個數

DH

1

每簇扇區數

EH

2

保留的扇區個數

10H

1

FAT個數

11H

2

不使用(根目錄數量,FAT32已突破此限制,已無效,一般為0

13H

2

不使用(扇區總數,小於32M時才使用)

15H

1

存儲介質描述符

16H

2

不使用(FAT占的扇區數,小於32M時才使用)

18H

2

每磁軌扇區個數

1AH

2

磁頭數

1CH

4

隱藏扇區

20H

4

扇區總數(大於32M時使用)

24H

4

FAT占的扇區數(大於32M時使用)

28H

2

擴展標記

2AH

2

版本,一般為0

2CH

4

根目錄的首簇號

30H

2

文件系統整體信息扇區號

32H

2

DBR備份所在的扇區號

34H

12

保留,固定為0

40H

1

BIOS驅動器號

41H

1

不使用,一般為0

42H

1

擴展引導標記

43H

4

捲序列號

47H

11

捲標

52H

8

文件系統類型名,固定為”FAT32   ”

 

FAT32文件系統在DBR的保留扇區中一個文件系統信息扇區,用以記錄數據區中空閑簇的數量及下一個空閑簇的簇號,該扇區一般在分區的LAB1扇區,也就是緊跟著DBR後的一個扇區,其內如下:

 

褐色:擴展引導標簽,為52 52 61 41ASCII”RRaA”

青色:文件系統信息簽名,為72 72 41 61ASCII”rrAa”

藍色:空閑簇的數量,(1FBB0)=129968,每個簇1K,約等於127MB,即D盤的大小

紫色:下一個空閑簇的簇號

黃色:結束標記

其他位元組:不使用,填充0

 

由於FAT緊跟在DBR的保留扇區之後,所以定位到最後一個保留扇區,那麼下一個扇區就是FAT啦!

在上面的DBR圖中可以找到保留扇區的個數為20H=3220 00是小端表示法),所以DBR往後32個扇區就是首要FAT啦,如圖:

 

 

FAT4位元組(32位)為一個表項,每個表項值的含義:

0x0000 0000

空閑簇,可用簇

0x0000 0001

保留簇

0x0000 0002 ~ 0x0FFF FFEF

該簇已用,其值指向下一個簇號

0x0FFF FFF0 ~ 0X0FFF FFF6

這些值保留,不使用

0x0FFF FFF7

壞簇,當一個簇中有一個扇區損壞(如物理損壞、病毒感染)時稱為壞簇,這個簇將不被FAT32使用

0x0FFF FFF8 ~ 0x0FFF FFFF

文件的最後一個簇

每個表項的值對應了相應簇的使用情況,如2號表項對應了2號簇的使用情況,3號表項對應了3號簇的使用情況,註意的是,最開頭的兩個表項是不使用的,它們代表FAT的表頭,其值是固定的0xFFF FFF80xFFFF FFFF,所以!FAT32中不存在0號簇和1號簇,第1個簇是2號簇!畫張圖:

 

 

如果該簇是文件的最後一簇,填入的值為0x0FFFFFFF,如果該簇不是文件的最後一簇,則填入的值為該文件占用的下一簇號所以可以看FAT32文件系統中文件是以簇鏈表的形式保存起來的)。

2號表項存儲的是2號簇的使用情況,一般2(也就是文件系統的第1個簇)存儲的是文件系統的根目錄雖然在FAT32中,根目錄的位置不再硬性固定,可以存儲在分區內可定址的任意簇內,不過通常根目錄是最早建立的格式化時)目錄所以基本上都是根目錄首簇緊鄰FAT2,占簇區順序上的第1個簇(即2號簇)同時,FAT32將根目錄當做普通的數據文件,所有沒有了目錄數的限制,在需要的時候可以分配空簇這一項2號表項)的值為0x0FFFFFFF ,說明當前根目錄占了1個簇的大小

現在來分析數據區,數據區是緊接在FAT2之後的,所以在DBR往後(保留扇區+FAT1占用的扇區+FAT2占用的扇區)個扇區就是數據區啦,如圖(這是數據區的第一個扇區,也是第一個簇的前半部分):

 

發現前11位元組是我們的捲標!

 

 

而在BPB中捲標那項的值永遠是”NO NAME    ”,也就是說捲標被移動到了數據區的前11位元組,而且FAT32捲標最長11位元組(因為BPB中已經規定了),而NTFS已經突破了這個限制。

其實,捲標是根目錄下的第一個文件!

 

現在來分析一下FAT32下文件和目錄之間是如何組織的,如何存儲的,如何保存屬性的:

先低級格式化D盤,以確保分區乾凈(指的是數據區全填充為0),

 

 

低級格式化完成(如果分區較大,低格的速度會變慢,耐心等待)之後,查看一個首要FAT表,

 

 

有一個表項,它的值為FFF FFFFH,意思就是結束簇,這就是我們的根目錄啦,再查看一個根目錄所在的起始簇,

 

 

發現前兩行(32位元組)有數據,後面全是0,然後我們在D盤(根目錄)下粘貼一個空文件(在其他盤(如C盤)新建一個文本文件,然後複製到D盤,下麵會講為什麼不能直接在D盤新建文件,而非要從其他盤複製),

 

 

再去首要FAT中查看變化,發現沒有變化,看起來新建的文件不占表項,再去根目錄所在簇查看一下,

 

 

發現!多了2行(32位元組),這就是我們剛剛新建(其實是粘貼)的空文件A.TXT啦,現在我們要引入一個FAT32下短文件目錄項概念了,來個表格,

位元組偏移

位元組數

說明

0H

8

文件名

8H

3

尾碼名,擴展名,類型名

BH

1

文件屬性

0000 0000B, 0H 讀寫

0000 0001B, 1H 只讀

0000 0010B, 2H 隱藏

0000 0100B, 4H 系統

0000 1000B, 8H 捲標

0001 0000B, 10H 子目錄

0010 0000B, 20H 歸檔

CH

1

保留

DH

1

創建時間的10毫秒位

EH

2

創建時間

10H

2

創建日期

12H

2

最後一次訪問的日期

14H

2

起始簇號的高16

16H

2

最近一次修改的時間

18H

2

最近一次修改的日期

1AH

2

起始簇號的低16

1CH

4

文件長度

可以看出文件長度為0,起始簇號高16位為0H,低16位也為0H,也就是指向0號簇,但是0號簇不存在,所以此文件不存在起始簇,也就驗證了文件長度為0,現在我們用記事本打開此文件,向其中寫幾個單詞,

 

再來看看此文件的屬性,

 

 

現在先去看一下首要FAT的變化,

 

 

哈哈,多了一個表項哦,這個多的表項的值也是FFF FFFFH,也就是結束簇,我們再去根目錄所在簇看看,

 

 

發現了沒,起始簇號和文件長度都發現了相應的變化,圖中給出了計算值,這符合前面用右鍵查看的A.TXT屬性,且起始簇號為3也是正確的,因為簇號2被根目錄所占用,那麼下一個簇號就是3啦,現在我們去簇號3看看,

 

 

現在我們將A.TXT增加到幾KB(我從網上找了微軟的百度百科複製了其中一段),這裡需要註意,因為我這個D盤的簇大小僅僅為1KB,所以大於1KB就可以完成本步驟的實驗了,如果你們的簇大小為NKB,那麼A.TXT需要大於NKB才行,

 

 

然後我們先去根目錄查看一下,

 

 

數值又發生了變化,但是一定和上圖的屬性中一樣,這裡不再計算,然後我們再去首要FAT看一下,

 

 

發現,多了6項,且原來的3號表項已經不是FFF FFFFH了,取而代之的是9號表項變成了FFF FFFFH,這樣就形成了簇鏈,文件系統讀取時就通過這個單鏈表讀取,我們簡單計算一下,A.TXT最多占7個簇(第7個簇恰好全部用完,即占用空間的大小),最少占6個簇(第7個簇只用了1個位元組),那麼推測出A.TXT大小在[6144+1,7168]位元組,而A.TXT在其的屬性截圖中大小為6546位元組,占用空間為7168位元組,完全符合,

現在我們來看一下FAT32的長文件目錄項格式(現在基本用的都是長文件名啦),

位元組偏移

位元組數

說明

0H

1

7位:保留

6位:1表示長文件最後一個目錄項

5位:保留

0~4位:順序號

1H

10

Unicode文件名第1部分

BH

1

長文件名目錄項標誌,值預設FH

CH

1

保留

DH

1

校驗值(根據短文件名計算)

EH

12

Unicode文件名第2部分

1AH

2

起始簇號

1CH

4

Unicode文件名第3部分

我們再從其他盤複製過來一個長文件名的空文本文件,

 

 

查看一下根目錄,

 

長文件名是以鏈表方式存儲的,所以能存很長很長的文件名,文件名結束符為’\0’,即0H,如果結束符之後還有剩餘的Unicode字元則以FFH填充,在長文件目錄項的最後兩行是它的短目錄項存儲格式哦,簡單說一下為什麼長文件目錄項第1行第1位元組為43H,下圖,

 

 

至此,簡單的FAT32組織結構已經介紹完了,歡迎讀者深入探究。

附上,一篇寫FAT32不錯的博文:https://blog.csdn.net/yangyang031213/article/details/79030247

 

來說一下為什麼上面要複製其他盤的文件到D盤,因為直接在D盤新建一個文本文件是“新建 文本文檔.txt”,然後我們將它重名名為“NEW.TXT”,然後在winhex查看,發現還是存在一個“新建 文本文檔.txt”的,只不過是刪除狀態的,所以為了避免這項因素的干擾,我就選擇了從其他盤複製文件過來。

 

附上簇的取值範圍表:

分區大小

FAT32預設簇大小

32~256M

中間還分多個擋位:512B,1K,2K

257M~8G

4K

8G~16G

8K

32G~2T

32K

 

 

題外話,也算是一個練習,驗證網上說的FAT32最大隻能存放4G的文件”:

因為FAT32中目錄項中每個文件的文件長度是4位元組,4位元組最大能定址的位元組數為232次,換算為G就是4G啦,即2^32B/1024^3=4G

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 剛接觸線程的時候,感覺這個東西好神奇。雖然不是很明白,就感覺它很牛逼。 參考了一些大佬寫的文章: https://www.cnblogs.com/yilezhu/p/10555849.html這個大佬寫的文章,我還是很喜歡的 https://www.cnblogs.com/mushroom/p/45 ...
  • 1. 多線程向同一文件寫入Log. ...
  • 第一種:根據單個分隔字元用split截取 第二種:利用多個字元來分隔字元串 第三種:根據字元串或字元串組來截取字元串 第四種:提取字元串中的第i個字元開始的長度為j的字元串 第五種:提取字元串中右數長度為i的字元串 第六種:替換字元串中的特定字元串 第七種:刪除字元串中的特定字元串Jiangj 第八 ...
  • <Style TargetType="{x:Type DatePickerTextBox}"> <Setter Property="Control.Template"> <Setter.Value> <ControlTemplate> <TextBox x:Name="PART_TextBox" T... ...
  • 場景 C#窗體應用中使用ZedGraph曲線插件繪製圖表: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/99716066 Winforn中設置ZedGraph曲線圖的屬性、坐標軸屬性、刻度屬性: https://blog.csd ...
  • 大多數應用都離不開配置,本章將介紹ASP.NET Core中常見的幾種配置方式及系統內部實現的機制。(ASP.NET Core 系列目錄) 說到配置,第一印象可能就是“.config”類型的xml文件或者“.ini”類型的ini文件,在ASP.NET Core 中,常用的配置文件類型為JSON。比如 ...
  • 繼續學習打卡,這幾天有事所以看視頻補上了這幾天的學習進度。 day4:主要重點 tar打包和解壓命令 tar -zxvf xxx.tar.gz 解壓xxx.tar.gz (將xxx.tar.gz解壓到當前目錄,參數-z:使用gzip壓縮格式解壓,-x:表示解壓,-v:顯示壓縮或解壓過程,-f:目標文 ...
  • 修改命令提示符顏色 修改命令提示符的話,只需修改PS1環境變數即可。 效果如圖: 修改命令輸入的顏色 修改命令輸入的顏色,思路是不關閉PS1的顏色,然後在每次敲下回車鍵執行命令的時候自動插入顏色終止符。這需要藉助trap捕獲DEBUG信號來實現。 如果要寫入shell配置文件,建議寫到 ,而不要寫入 ...
一周排行
    -Advertisement-
    Play Games
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...