解析DBR操作系统引导记录数据

解析DBR操作系统引导记录数据

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

理解文件系统。你必须要熟悉DBR,下面我们就来看看文件系统解析DBR数据

Dos Boot Record(DBR)操作系统引导记录是由操作系统的格式化程序建立的。在文件系统驱动操作不论什么一个磁盘卷时,这一部分的信息将被读取并作为文件系统在这个磁盘卷上的參数被使用。它包括了有效的引导程序、厂商标志、BPB数据块等。

1.那么怎么得到DBR呢?它位于分区的第一个扇区。而分区的地址能够从磁盘的第一个分区的分区表项中获得。

详细可參考http://blog.csdn.net/liyun123gx/article/details/38420665

2.分析本扇区数据

以下是一个FAT文件系统的DBR的信息

解析DBR操作系统引导记录数据

(注意 数据以小端格式存储的)

0x01~0x02:      3个字节。跳转指令。

跳转到DBR后面一点的引导程序处。引导程序是一段用来载入真正操作系统的程序。

0x03~0xA:        8个字节,OEM串。本例中是MSDOC5.0

0X0B~0X0C:     2个字节,每扇区的字节数。

本例是0X0200,512

0X0D                1个字节,每簇的扇区数。

本例是0x8

0X0E~0X0F:     2个字节,保留扇区数。本例是0x0026

0X10:             1个字节,FAT表个数。本例是0x02

0X11~0X12:   2个字节。根文件夹最多可容纳的文件夹项数。FAT12和FAT16通常为512,FAT32不使用此值,为0.本例中是FAT32,所以为0.

0X13~0X14:   2个字节,扇区总数。

小于32MB时使用该处存放,超过32MB的使用偏移0x20~-x23字节处的4字节存放。

本例中磁盘为7G多,故为0.

0X15:            1个字节,介质描写叙述。

本例中0XF8表示本地硬盘。

0X16~0X17:   2个字节。每一个FAT表的扇区数。相同。FAT32不使用,为0.

0X18~0X19:   2个字节,每一个磁道的扇区数。

本例是0X3F,63

0X1A~0X1B:     2个字节,磁头数。本例是0XFF,255

0X1C~0X1F:     4个字节。分区前已经使用的扇区数,隐藏扇区数。本例是 0X 00 00 00 3F,63

0X20~0X23:   4个字节,文件系统扇区数。本例是 0X00 EA 58 78,15358072

0X24~0X27:   4个字节,每一个FAT表的扇区数。本例是 0X00 00 3A 79。14969

0X28~0X29:   2个字节,标记。

0x2A~0x2B:    2个字节,版本。

0x2C~0x2F:    4个字节。根文件夹簇号,2。(尽管在FAT32文件系统下。根文件夹能够存放在数据区的不论什么位置,可是通常情况下还是起始于2号簇)

0x30~0x31:     2个字节,FSINFO(文件系统信息扇区)扇区号。1。该扇区为操作系统提供关于空簇总数及下一可用簇的信息。

0x32~0x33:     2个字节,备份引导扇区的位置。6。

备份引导扇区总是位于文件系统的6号扇区。

0x34~0x3F:     12个字节。未使用。

0x40~0x40:     1个字节,BIOS INT 13H 设备号,0x80。

0x41~0x41:     1个字节,未用。

0x42~0x42:     1个字节。扩展引导标志。0x29。

0x43~0x46:     1个字节,卷序列号。通常为一个随机值。

0x47~0x51:     11个字节,卷标(ASCII码)。假设建立文件系统的时候指定了卷标,会保存在此。本例中是NO NAME

0x52~0x59:     8个字节。文件系统格式的ASCII码,FAT32。

0x5A~0x1FD:  410个字节,未使用。

该部分没有明白的用途。

0x1FE~0x1FF: 签名标志“55 AA”。

3.FSINFO信息扇区

FSINFO一般位于文件系统的1号扇区。就是DBR的下一个扇区。它用来记录文件系统中空暇簇的数量以及下一可用簇的簇号等信息。

解析DBR操作系统引导记录数据

以下介绍一下FSINFO的结构

0x00~0x03:          4个字节,扩展引导标志“52526141”。

0x04~0x1E3:    480个字节,未使用,所有置0。

0x1E4~0x1E7: 4个字节,FSINFO签名“72724161”。

0x1E8~0x1EB: 4个字节,文件系统的空簇数。41207688(0x00 12 6D 88)。

0x1EC~0x1EF: 4个字节。下一可用簇号,663(0x00 00 02 97)。

0x1F0~0x1FD: 14个字节,未使用。

0x1FE~0x1FF: 2个字节,“55 AA”标志。


注意:通常情况下,文件系统的2号扇区结尾也会被设置“55 AA”标志。6号扇区也会有一个引导扇区的备份,对应的,7号扇区应该是一个备份FSINFO信息扇区。8号扇区能够看做是2号扇区的备份,它的结尾也会有一个“55 AA”标志。

4.以下是一个NTFS文件系统的DBR

解析DBR操作系统引导记录数据

0x01~0x02:      3个字节。跳转指令。

0x03~0xA:        8个字节。文件系统的字符串。

本例中是NTFS

0X0B~0X0C:     2个字节,每扇区的字节数。本例是0X0200,512

0X0D                1个字节,每簇的扇区数。本例是0x8

0X0E~0X0F:      2个字节。保留扇区数。本例是0x0000

0X10~0X13:   4个字节。未使用

0X15:            1个字节,介质描写叙述。本例中0XF8表示本地硬盘。

0X16~0X17:   2个字节,总为0.

0X18~0X19:   2个字节,每一个磁道的扇区数。本例是0X3F,63

0X1A~0X1B:     2个字节。每一个柱面的磁头数。

本例是0XFF,255

0X1C~0X1F:      4个字节,隐含扇区数。本例是 0X 0C 81 98 00,209819648 

0X20~0X23:    4个字节,未使用

0X24~0X27:    4个字节,未使用。一般都为0X80 00 80 00

0X28~0X2F:    8个字节,该分区的扇区数。

本例为0X00 00 00 00 19 01 8F FF,419532799

0x30~0x37:     8个字节,$MFT的起始逻辑簇号。本例为0X00 00 00 00 00 0C 00 00

0x38~0x3F:     8个字节。$MFTMirr(MFT文件的镜像文件)的起始逻辑簇号。本例为0X00 00 00 00 00 00 00 02

0x40~0x43:     4个字节。每一个MFT记录所占的簇数。

本例中为0XF6 00 00 00

0x44~0x47:     4个字节,每索引簇数,通常每索引簇数为1个簇。

本例为0X00 00 00 01

0x48~0x4F:     8个字节。分区的逻辑序列号。这个序列号是硬盘格式化时随机产生的。本例为0X14 A2 8F A3 A2 8F 87 C6

0x50~0x53:     4个字节,校验和。

为0X00 00 00 00 00 

0x54~0x1FD:   426个字节,自举代码

0x1FE~0x1FF:     结束标志

版权声明:本文博客原创文章,博客,未经同意,不得转载。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/117710.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • JAVA生成uuid_java接口default方法

    JAVA生成uuid_java接口default方法java生成UUID的方法总结前言:我们开发的时候,数据库表总会有一个主键,以前我们可能会使用自增的数字作为主键。这样做去确实查询的时候比较快,但是在做系统集成或者数据迁移的的时候就麻烦了。这是id就有可能重复了。那么有什么比较好的方法解决这一问题呢?于是jdk1.5出了UUID这个类来生成唯一的字符串标识。知识点一:什么是UUID?UUID含义是通用唯一识别码(UniversallyUniqu

    2022年9月22日
    2
  • 简单的说下nginx和apache的区别~~~[通俗易懂]

    简单的说下nginx和apache的区别~~~[通俗易懂]浅谈nginx和apache的优缺点~~~一、分别介绍nginx和apache1.nginx2.apache二、apache相对于nginx的优缺点1.优点2.缺点总结一、分别介绍nginx和apache1.nginx什么是nginx:Nginx是一个高性能的HTTP和反向代理服务器,同时还是IMAP/POP3/SMTP代理服务器,该程序由俄罗斯Rambler.ru站点开发,Nginx因为性能稳定、低系统资源消耗而闻名,近几年Nginx在国内已经成炙热化状态,比如像腾讯、网易、51CTO、迅雷、当当

    2022年5月29日
    34
  • 求一个微信签到小程序的源码

    求一个微信签到小程序的源码RT 谢谢大神们

    2025年6月13日
    2
  • java中的break和continue「建议收藏」

    java中的break和continue「建议收藏」java中的break和continue

    2022年4月25日
    46
  • python 自动化操作 模块_自动化的基本原理

    python 自动化操作 模块_自动化的基本原理1)什么是xlrd模块?python操作excel主要用到xlrd和xlwt这两个库,即xlrd是读excel(excelread),xlwt是写excel(excelwrite)的库。(2)为什么使用xlrd模块?在UI自动化或者接口自动化中数据维护是一个核心,所以此模块非常实用。xlrd模块可以用于读取Excel的数据,速度非常快,推荐使用!常用单元格的数据类型empty(空的)numberdatebooleanerrorblank(空白表格)导入模块常用的函数。…

    2022年9月26日
    3
  • 在Pycharm中安装matplotlib

    在Pycharm中安装matplotlib 1.初学python——安装matplotlib在pycharm中安装第三库不需要下载:打开pycharm,点击fileàsettings2.选择Project:dataview(项目名字)àprojectInterpreterà点击+号 3.进入后,在输入框中输入matplotlib进行搜索,然后选中要安装的包并点击下方的installpackage…

    2022年6月17日
    41

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号