分析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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...