U盘文件误删除了,想通过数据恢复软件修复,发现恢复回来的文件是损坏的。用winhex打开一看基本都是0,顿时对数据恢复软件很失望!想自己来恢复,同时一探究竟! 说 明: 操作系统:win7 旗舰版 64位 U 盘:16G 所有地址均指物理地址 注意winhex软件与物理地址的相对性 1.0 文件的位置确定 1.1 引导扇区(DBR) 图1 这是我的U盘引导扇区截图,有用的数据均做颜色标记。 黑色(0x0B 0x0C) :0x0200 (每个扇区512字节) 绿色(0x0D) :0x10 (一个簇包含16个扇区,既512 * 16 =8096) 红色(0x0E 0x0F) :0x08BE(2238,保留扇区大小) 粉色(0x20~23) :0x01DD7FFF(31293439,扇区总数) 紫色(0x24~27) :0x00003BA1(15265,FAT表所占用扇区数) 黄色(0x2c~2F) :0x00000002(2,根目录所在第一个簇的簇号) DBR具体参数说明:http://www.inhdd.com/1603448.html 图2 我们需要确定数据区的起始地址 = 橙色 + 绿色 + 黄色 绿色和黄色的地址 = (0x08BE + 0x3BA1 * 2 )* 512 = 0x1000000 橙色 = 0x0400000 数据区的起始地址 = 0x01400000 这个地址也是根目录所在的位置 1.2 根目录文件查找 为了便于分析,这里专门在根目录下建了一个123456.txt的文件,跳转到0x01400000位置 图3 红色是文件名称 绿色是文件的存储簇号(0x00016AC6) 文件的位置存储内容如下图: 图4 1.3FAT表 图片中红色方框即为123456.txt文件存储的位置。 FAT表的起始地址为:0x000117C00 123456.txt存储地址为起始地址+偏移地址 0x000117C00 + 0x00016AC6 *4 = 0x0172718 图5 2.0 删除文件 现在人为删除123456.txt文件,然后来对比根目录和FAT表的变化。 首先看一下根目录: 图6 和图3对比会发现,红色和绿色都改变了,变化的数据标为蓝色。我们知道绿色部分为文件存储的起始簇,这个数据变化了,那么恢复文件的可能性就比较难了。我们再去看看FAT表做了哪些修改。 图7 和图5对比,发现原来的结束簇标志被清除了,变为0. 最后我们去看看文件数据是否也删除了! (0x00016AC6-0x02) * 16 * 512 = 0x2D588000 公式说明: 0x00016AC6,簇的位置 0x2,簇从3开始有效 16 ,每个簇16个扇区 512 每个扇区512字节 这个地址是基于数据区的起始地址0x01400000 所以123456.txt实际地址 = 0x01400000 +0x2D588000 = 0x02E588000 图8 3.0总结 根据分析发现和实际测试,发现电脑的删除操作清除了FAT表的簇号和目录的起始簇地址高16位,但是文件的实际数据还是存储在U盘当中,当然删除后再次写入除外。所以当起始簇有在高16位的文件,软件恢复的可能性不大,当起始簇只有低16位的,恢复起来比较容易。 |
针对SMR叠瓦式硬盘存在的问题,西数正在用更先进的技术解决,他们开
固态硬盘不认盘了能做数据恢复吗?从专业数据恢复层面来讲,当前有一
如今固态硬盘基本成为了标配,机械硬盘相比固态硬盘在读写速度在存在