zip文件格式

南邮平台上的一道题很有意思

首先文件名叫做丘比龙de女神

文件名叫做gif 因此我们修改后缀没有任何发现

zip文件格式_第1张图片

用HxD打开,在文件末尾发现50 4B 05 06,这是zip文件的标志,而且文件里有nvshen.jpg

zip文件格式_第2张图片

改后缀名为zip,打不开显示文件损坏。

0X 3B是gif尾标记。

zip文件格式_第3张图片

后面是zip包,但是我们没有看到pk头,因此我们修改6C 6F 76 65为 50 4B 05 06并复制到末尾到新的文件中,解压得到

nvshen.jpg在kali里由md5sum

得到flag

总结:pk头:50 4B 05 06 zip文件标记位

         0x 3B gif文件的末尾位

zip

压缩源文件数据区: 
50 4B 03 04:这是头文件标记(0x04034b50) 
14 00:解压文件所需 pkware 版本 
00 00:全局方式位标记(有无加密) 
08 00:压缩方式 
5A 7E:最后修改文件时间 
F7 46:最后修改文件日期 
16 B5 80 14:CRC-32校验(1480B516) 
19 00 00 00:压缩后尺寸(25) 
17 00 00 00:未压缩尺寸(23) 
07 00:文件名长度 
00 00:扩展记录长度 
6B65792E7478740BCECC750E71ABCE48CDC9C95728CECC2DC849AD284DAD0500 
压缩源文件目录区: 
50 4B 01 02:目录中文件文件头标记(0x02014b50) 
3F 00:压缩使用的 pkware 版本 
14 00:解压文件所需 pkware 版本 
00 00:全局方式位标记(有无加密,这个更改这里进行伪加密,改为09 00打开就会提示有密码了) 
08 00:压缩方式 
5A 7E:最后修改文件时间 
F7 46:最后修改文件日期 
16 B5 80 14:CRC-32校验(1480B516) 
19 00 00 00:压缩后尺寸(25) 
17 00 00 00:未压缩尺寸(23) 
07 00:文件名长度 
24 00:扩展字段长度 
00 00:文件注释长度 
00 00:磁盘开始号 
00 00:内部文件属性 
20 00 00 00:外部文件属性 
00 00 00 00:局部头部偏移量 
6B65792E7478740A00200000000000010018006558F04A1CC5D001BDEBDD3B1CC5D001BDEBDD3B1CC5D001 
压缩源文件目录结束标志: 
50 4B 05 06:目录结束标记 
00 00:当前磁盘编号 
00 00:目录区开始磁盘编号 
01 00:本磁盘上纪录总数 
01 00:目录区中纪录总数 
59 00 00 00:目录区尺寸大小 
3E 00 00 00:目录区对第一张磁盘的偏移量 
00 00:ZIP 文件注释长度

这儿可以引出zip伪加密 只要00 0X (X为奇数就是加密)

同样的修改pk位也可以起到相同的效果。
资源中有文件头标记位可以下载。

你可能感兴趣的:(zip文件格式)