实验一:
目的:用于生成大量模拟破坏GPT分区结构案例,并生成唯一方式修复后的评判方法。
故障:在一个完整的GPT分区磁盘上,丢失了GPT主分区表,或备份分区表。
要求:
1、利用WINHEX手工方式,修复给定镜像文件的分区结构。
2、不得对现存主分区表或备份分区表做任何修改。
3、不得使用WINHEX GPT分区模板进行参考修复。
4、修复后生成整个镜像文件的MD5 HASH值。
实验样本生成过程:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
#!/bin/sh
#删除头部做50个
for
((i=1;i<=50;i++));
do
r1=$(($i+200))
qemu-img create -f raw $i.img
"$r1"
M
losetup
/dev/loop0
$i.img
parted -s
/dev/loop0
mklabel gpt
parted -s
/dev/loop0
mkpart -s primary ext3 128s 100%
dd
if
=
/dev/loop0
2>
/dev/null
|md5sum -b|
tr
a-z A-Z 1>>md5.txt
dd
if
=
/dev/loop0
of=
head
"$i"
.img bs=512 count=64
dd
if
=
/dev/zero
of=
/dev/loop0
bs=512 seek=1 count=2048
dd
if
=
/dev/loop0
of=f
"$i"
.img
tar
-zcvf f
"$i"
.
tar
.gz f
"$i"
.img
rm
f
"$i"
.img
losetup -D
rm
$i.img
done
#删除尾部做50个
for
((i=51;i<=100;i++));
do
r1=$(($i+200))
r2=$(($r1*2048-64))
qemu-img create -f raw $i.img
"$r1"
M
losetup
/dev/loop0
$i.img
parted -s
/dev/loop0
mklabel gpt
parted -s
/dev/loop0
mkpart -s primary ext3 128s 100%
dd
if
=
/dev/loop0
2>
/dev/null
|md5sum -b|
tr
a-z A-Z 1>>md5.txt
dd
if
=
/dev/loop0
of=
tail
"$i"
.img skipk=$r2 bs=512
dd
if
=
/dev/zero
of=
/dev/loop0
bs=512 seek=$r2
dd
if
=
/dev/loop0
of=f
"$i"
.img
tar
-zcvf f
"$i"
.
tar
.gz f
"$i"
.img
rm
f
"$i"
.img
losetup -D
rm
$i.img
done
|
实验二:
目的:用于生成大量模拟破坏GPT分区结构案例,并生成唯一方式修复后的评判方法。
故障:在一个完整的GPT分区磁盘上,之前有一个位置不确定的分区(脚本中起始于100~150M,结束于350~400M),现在被重新分区后变成了一个完整的大分区。
要求:
1、利用WINHEX手工方式,修复给定镜像文件的分区结构。
2、仅在现有分区表项上做修改,仅修改其起始位置,结束位置。
3、不得使用WINHEX GPT分区模板进行参考修复。
4、修复后生成整个镜像文件的MD5 HASH值。
实验样本生成过程:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
#!/bin/bash
for
((i=1;i<=100;i++));
do
r1=$(($RANDOM % 50+100))
r2=$(($RANDOM % 50+350))
qemu-img create -f raw $i.img 500M
losetup
/dev/loop0
$i.img
parted -s
/dev/loop0
mklabel gpt
parted -s
/dev/loop0
mkpart -s primary ext3
"$r1"
M
"$r2"
M
mkfs.ntfs -f
/dev/loop0p1
dd
if
=
/dev/loop0
2>
/dev/null
| md5sum -b|
tr
a-z A-Z 1>>md5.txt
dd
if
=
/dev/loop0
2>
/dev/null
|
gzip
>s
"$i"
.gz
parted -s
/dev/loop0
rm
1
parted -s
/dev/loop0
mkpart -s primary ext3 128s 100%
dd
if
=
/dev/loop0
2>
/dev/null
|
gzip
>
"$i"
.gz
losetup -D
rm
$i.img
done
|
本文转自 张宇 51CTO博客,原文链接:http://blog.51cto.com/zhangyu/1940719,如需转载请自行联系原作者