实验FAT32-1说明:FAT32-1.img是一个包含FAT32文件系统的磁盘镜像,请使用winhex手工方式读出这个文件系统内的指定文件,并回答其md5 HASH值。
要求:
1、利用WINHEX手工方式读取。
2、不得使用WINHEX模板功能。
3、不得使用WINHEX文件系统解析功能。
4、填写的MD5 HASH值全部为大写,不包括0x头标或H尾标,中间不得有任何间隔符号(包括空格、制表符、’-’等符号),以WINHEX软件运算出的HASH值为准。
实验目的:
1、实现手工方式跟踪一个FAT32文件系统,并读出指定的某个文件。
2、理解多目录块的组合方式。
3、理解多个文件碎片的处理方式。
4、理解DBR、FAT表等文件系统组件。
5、熟练使用WINHEX
题库:
1、实验X中,\FROMBYTE51\28.txt文件的md5 HASH值为___________?
2、实验X中,\FROMBYTE55\8.txt文件的md5 HASH值为___________?
... ...
附:实验环境生成脚本:
#!/bin/bash qemu-img create -f raw FAT32-1.img 500M losetup /dev/loop0 FAT32-1.img parted -s /dev/loop0 mklabel msdos parted -s /dev/loop0 mkpart -s primary fat32 128s 100% mkfs.fat -F 32 -s 8 /dev/loop0p1 mount /dev/loop0p1 /mnt for((i=1;i<=150;i++));do mkdir /mnt/"FROMBYTE"$i for((ii=1;ii<10;ii++));do r2=$(($RANDOM % 32 + 512)) #create file r3=$(($RANDOM % 32)) for((iii=1;iii<$r2;iii++));do if [ $r3 -eq $iii ] ;then # random write "COPY RIGHT" echo -n "*****COPY RIGHT:" >>/mnt/"FROMBYTE"$i/$ii.txt r3=$(($RANDOM % 32 + $r3)) else echo -n "www.frombyte.com" >>/mnt/"FROMBYTE"$i/$ii.txt fi done done done for((i=1;i<=150;i++));do for((ii=1;ii<10;ii++));do r2=$(($RANDOM % 512 + 512)) #add padding r3=$(($RANDOM % 32)) for((iii=1;iii<$r2;iii++));do if [ $r3 -eq $iii ] ;then # random write "COPY RIGHT" echo -n "*****COPY RIGHT:" >>/mnt/"FROMBYTE"$i/$ii.txt r3=$(($RANDOM % 32 + $r3)) else echo -n "www.frombyte.com" >>/mnt/"FROMBYTE"$i/$ii.txt fi done done done for((i=65;i<=150;i++));do md5sum /mnt/"FROMBYTE"$i/* |tr a-z A-Z >>~/FAT32-1/FAT32-1.md5 done cd umount /dev/loop0p1 losetup -d /dev/loop0
总过程:
1、按上述脚本生成md5集合FAT32-1.md5,FAT32-1.img镜像
2、通过FAT32-1.md5,生成题库。方法有:
a、利用excel编辑替换的方式生成
b、linux下使用awk 、sed加shell的方式生成
c、利用python生成
示例,使用awk、sed生成题库(为容易看,断行,执行时一行即可,考题里的格式仍有出入,仅做演示,可以针对情况修改)
sed -e 's/\/MNT//' -e 's/TXT/txt/' FAT32-1.md5 |awk '{print "test2:",$2," ,this file MD5 HASH is:0x___. ","\\\\"$1"\\\\easy\\\\.."}' >test.txt
结果如下(截取部分):
test2: /FROMBYTE95/8.TXT ,this file MD5 HASH is:0x___. \\46D40D302D0CEBCF541086589E9FCCFB\\easy\\..
test2: /FROMBYTE95/9.TXT ,this file MD5 HASH is:0x___. \\D15F6065CDA928F5A581225AD2FA0AD0\\easy\\..
test2: /FROMBYTE96/1.TXT ,this file MD5 HASH is:0x___. \\646E1F87F8458D0423FE9E64EBBD1908\\easy\\..
test2: /FROMBYTE96/2.TXT ,this file MD5 HASH is:0x___. \\0E7C3DCBF868495E43BD6A34CE6D8418\\easy\\..
test2: /FROMBYTE96/3.TXT ,this file MD5 HASH is:0x___. \\681757B565DB23A467CDB527D2D107C8\\easy\\..
test2: /FROMBYTE96/4.TXT ,this file MD5 HASH is:0x___. \\C2FCEEBEE9FD30D107C0D5D57E5785A2\\easy\\..
test2: /FROMBYTE96/5.TXT ,this file MD5 HASH is:0x___. \\09F17DBAACA7AC8277457B5A97B14D66\\easy\\..
test2: /FROMBYTE96/6.TXT ,this file MD5 HASH is:0x___. \\3C63DB19A48086A33A31620346EB5F9B\\easy\\..
test2: /FROMBYTE96/7.TXT ,this file MD5 HASH is:0x___. \\B8FFC3B07E67D85E60B5B71367D75D90\\easy\\..
test2: /FROMBYTE96/8.TXT ,this file MD5 HASH is:0x___. \\12FC052979EAD0BC0C398E275CB6F56D\\easy\\..
test2: /FROMBYTE96/9.TXT ,this file MD5 HASH is:0x___. \\6C2055640D7FA21C6E9F8A31AB3A4C50\\easy\\..
test2: /FROMBYTE97/1.TXT ,this file MD5 HASH is:0x___. \\94791A0E619868560DF475AB96B5AE4D\\easy\\..
test2: /FROMBYTE97/2.TXT ,this file MD5 HASH is:0x___. \\F31D153B05329D5D22B74B06EEAB86A6\\easy\\..
test2: /FROMBYTE97/3.TXT ,this file MD5 HASH is:0x___. \\6B8375017CB05325CA565D586C596BE8\\easy\\..
test2: /FROMBYTE97/4.TXT ,this file MD5 HASH is:0x___. \\58E0129F24A5915D4BA957D90C05892A\\easy\\..
test2: /FROMBYTE97/5.TXT ,this file MD5 HASH is:0x___. \\66E2B4CD85DABA2ECEB810476B982538\\easy\\..
test2: /FROMBYTE97/6.TXT ,this file MD5 HASH is:0x___. \\502514DE713A04FBAFE3A44C8598028C\\easy\\..
test2: /FROMBYTE97/7.TXT ,this file MD5 HASH is:0x___. \\B66025D4FDD12837438ED36903F738A7\\easy\\..
test2: /FROMBYTE97/8.TXT ,this file MD5 HASH is:0x___. \\0F3B53E05AA6955A8377E55403E468F5\\easy\\..
test2: /FROMBYTE97/9.TXT ,this file MD5 HASH is:0x___. \\0A6EFA940D546735505D6847AFD4F9E0\\easy\\..
test2: /FROMBYTE98/1.TXT ,this file MD5 HASH is:0x___. \\E2567294C0EB341E43B1D26FF7372898\\easy\\..
test2: /FROMBYTE98/2.TXT ,this file MD5 HASH is:0x___. \\5624DA049E95F06475A2AF58BED6F050\\easy\\..
test2: /FROMBYTE98/3.TXT ,this file MD5 HASH is:0x___. \\8AB67DCDA00069208F1162C3FEF2BBD5\\easy\\..
改进的方法:用python改写脚本:
#!/usr/bin/python3 import os import random import hashlib import struct r=os.system rc=random.choice ri=random.randint md5=hashlib.md5 items = [1,2,3,4,5,6,7,8,9,10] r("cd ~/FAT32-1") fkaoti=open("FAT32-1-kaoti.txt",'w+') r("qemu-img create -f raw FAT32-1.img 500M") r("losetup /dev/loop0 FAT32-1.img") r("parted -s /dev/loop0 mklabel msdos") r("parted -s /dev/loop0 mkpart -s primary fat32 128s 100%") r("mkfs.fat -F 32 -s 8 /dev/loop0p1") r("mount /dev/loop0p1 /mnt") for i in range(1,151): r("mkdir /mnt/FROMBYTE%d" % i) for ii in range(1,11): f=open("/mnt/FROMBYTE%d/%d.txt"%(i,ii),'w+') for iii in range(1,ri(500,550)): if ri(1,32)==1: f.write("*****COPY RIGHT:") else: f.write("www.frombyte.com") f.close() for i in range(1,151): random.shuffle(items) for ii in items: f=open("/mnt/FROMBYTE%d/%d.txt"%(i,ii),'a') for iii in range(1,ri(1000,1100)): if ri(1,32)==1: f.write("*****COPY RIGHT:") else: f.write("www.frombyte.com") f.close() #//对65以后的目录生成MD5 HASH,65之后即不可能存在于第一个目录块(65*32*2 > 4096),考核FAT表对目录的跟踪 for i in range(65,151): for ii in range(1,11): fn="/mnt/FROMBYTE%d/%d.txt"%(i,ii) ff=open(fn,'r') data=ff.read() ff.close() fkaoti.write("实验FAT32-1中,文件系统中对\"%s\",人工读取内容后计算得到的文件MD5 HASH值为0x___。//%s//容易。。\n"\ % (fn,md5(data.encode("utf8")).hexdigest().upper()) ) fkaoti.flush() fkaoti.close() r("cd") r("umount /dev/loop0p1") r("losetup -d /dev/loop0")
总过程:
将FAT32-1.img和FAT32-1-kaoti.txt做相应处理即可。参考答案不可留在考试系统内。