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

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

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

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

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

2.分析本扇区数据

以下是一个FAT文件系统的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的下一个扇区。它用来记录文件系统中空暇簇的数量以及下一可用簇的簇号等信息。


以下介绍一下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


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://www.cnblogs.com/yxwkf/p/4610908.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/374870.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

简单冒泡排序

将5个数字按从小到大排序。 #include <stdio.h> #include <stdlib.h> #include <math.h> int main() {int x[5] {0},temp 0;for(int i 0;i<5;i){scanf("%d",&x[i]);}//冒泡排序&#xff08;升序&#xff09;for(int j 0;j<4;j)//n个…

YouTube Java API入门

在本教程中&#xff0c;我将介绍Google的YouTube API &#xff0c;该API可让您使用YouTube的功能来启用应用程序。 YouTube是“杀手级”互联网应用程序之一&#xff0c;其流量占互联网总流量的很大一部分。 在开始之前&#xff0c;请确保您已阅读《 API概述指南》 。 我们将主…

mysql在mac上的坑

默认端口3306&#xff1f; 正确答案&#xff1a;3307 转载于:https://www.cnblogs.com/dudream/p/5375551.html

ServletContext图解

servlet之间共享数据资源&#xff01; 转载于:https://www.cnblogs.com/felixzh/p/4615902.html

C语言怎么输出百分号%

规律&#xff1a;printf函数中&#xff0c;当出现多个%时&#xff0c;由左至右&#xff0c;每两个%结合输出一个% #include <stdio.h> #include <stdlib.h> #include <math.h> int main() {int c 52;printf("% \n %% \n %%% \n %%%% \n %%%%% \n %%%%…

入侵Jasper以获取JSP页面的对象模型

为了对我的JSP进行一些检查和统计分析&#xff0c;我需要一个包含在其中的元素的类似于DOM的层次模型。 但是&#xff0c;解析JSP页面并不是一件容易的事&#xff0c;最好留给它一个出色的工具-Tomcat&#xff0c;Jetty&#xff0c;GlassFish以及其他所有工具都可以使用Jasper …

Linux自动化安装cobbler

1介绍 1.1 PXE PXE技术与RPL技术不同之处为RPL是静态路由&#xff0c;PXE是动态路由。RPL是根据网卡上的ID号加上其他记录组成的一个Frame&#xff08;帧&#xff09;向服务器发出请求。而服务器中已有这个ID数据&#xff0c;匹配成功则进行远程启动。PXE则是根据服务器端收到的…

iOS9适配系列教程

https://github.com/ChenYilong/iOS9AdaptationTips 转载于:https://www.cnblogs.com/zsw-1993/p/4879118.html

C语言形参

形参和实参区别 形参出现在函数定义中&#xff0c;在整个函数体内都可以使用&#xff0c;离开该函数则不能使用。实参出现在主调函数中&#xff0c;进入被调函数后&#xff0c;实参变量也不能使用。 形参和实参的功能是作数据传送。发生函数调用时&#xff0c;主调函数把实参…

避免延迟的JPA集合

Hibernate&#xff08;实际上是JPA&#xff09;具有集合映射&#xff1a; OneToMany&#xff0c; ManyToMany&#xff0c; ElementCollection。 所有这些默认情况下都是惰性的。 这意味着集合是List或Set接口的特定实现&#xff0c;其中包含对持久会话的引用&#xff0c;并且只…

2016年,我的和自己谈谈

2016年过去三分之一了&#xff0c;现在谈规划晚点但总比没想法强。想了半天还是从这个方面着手吧&#xff1a; 一.升级改造自己的办公学习环境&#xff1a; 给自己的电脑加内存&#xff0c;加SSD&#xff0c;再添置一个显示器&#xff0c;换上心仪已久的cherry青轴键盘&#xf…

C语言的四舍五入实现

习题3-2 高速公路超速处罚 (15 分) 按照规定&#xff0c;在高速公路上行使的机动车&#xff0c;达到或超出本车道限速的10%则处200元罚款&#xff1b;若达到或超出50%&#xff0c;就要吊销驾驶证。请编写程序根据车速和限速自动判别对该机动车的处理。 输入格式: 输入在一行中…

ACTGame项目

项目地址&#xff1a;https://github.com/alonecat06/ACTGame游戏地址&#xff1a;http://pan.baidu.com/s/1hqD3IYw 项目是一个自制单机动作游戏demo&#xff0c;方向是手游&#xff0c;使用Unity5&#xff0c;5月中开工至今。 做这个项目&#xff0c;是为加深自己对Unity的理…

Xuggler教程:帧捕获和视频创建

注意&#xff1a;这是我们的“ Xuggler开发教程 ”系列的一部分。 到目前为止&#xff0c;在我们的Xuggler教程系列中&#xff0c;我们已经对视频处理的Xuggler进行了介绍&#xff0c;并讨论了转码和媒体修改 。 在本教程中&#xff0c;我们将看到如何解码视频和捕获帧&#xf…

面向对象-原型对象

创建对象 Js中可以用构造函数模式创建对象&#xff0c;如&#xff1a; function Person(name, age, job) {this.name name;this.age age;this.job job;this.sayName function () {alert(this.name);}}var person1 new Person("Nicholas", 29, "aa");v…

索引类型

1.B树索引 在Oracle中是通用索引&#xff0c;是创建索引时的默认索引。B树索引可以是单列索引&#xff0c;也可以是组合/复合索引。B树索引最多可以包括22列。 2.位图索引 位图索引时决策支持系统&#xff08;DSS&#xff09;和数据仓库的理想选择&#xff0c;它们不应该用于事…

C语言条件运算符

先看一个error error: lvalue required as left operand of assignment| i 0 ? X 1.0 : X * x;修改后 i 0 ? (X 1.0) : (X * x);也就是说条件运算符可以执行语句&#xff0c;当是赋值语句时要加括号规定优先级&#xff0c;不然会干扰程序判断。 因为条件运算符作为三目…

EJB 3.0注入和查找简介

介绍 Enterprise JavaBeans Specification v。3.0引入了简化的&#xff0c;基于注释的API&#xff0c;用于EJB注入和查找。 EJB 3.0现在是POJO&#xff0c;可以使用简单的注释将其注入其他组件&#xff08;例如EJB和Servlet&#xff09;。 EJB 3.0是Java EE 6的许多其他基于POJ…

SignalR + MVC5 简单示例

SignalR MVC5 简单示例 原文:SignalR MVC5 简单示例本文和前一篇文章很类似&#xff0c;只不过是把 SignalR 应用在了 MVC 中 新建项目&#xff0c;选择 MVC 模板 安装 SignalR Install-Package Microsoft.AspNet.SignalR 在项目中添加文件夹 Hubs 在 Hubs 文件夹中添加 Sign…

Java内存模型–快速概述和注意事项

在计算中&#xff0c; 内存模型描述了线程如何通过内存进行交互&#xff0c;或更一般地&#xff0c;它指定了为分段内存或分页内存平台生成代码时允许编译器进行的假设。 在给定程序和该程序的执行跟踪的情况下&#xff0c;它实质上描述了执行跟踪是否是该程序的合法执行。 Jav…