.zip格式和zip伪加密

0x01 ZIP文件的组成:

  • 压缩源文件数据区+压缩源文件目录区+压缩源文件目录结束标志

1、压缩源文件数据区

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:扩展记录长度

2、压缩源文件目录区:


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:局部头部偏移量

3、压缩源文件目录结束标志:

50 4B 05 06:目录结束标记

00 00:当前磁盘编号

00 00:目录区开始磁盘编号
 
01 00:本磁盘上纪录总数

01 00:目录区中纪录总数

59 00 00 00:目录区尺寸大小
 
3E 00 00 00:目录区对第一张磁盘的偏移量

00 00:ZIP 文件注释长度

0x02 示例

1、自己简单做一个zip压缩包,正常的压缩,压缩包内有三个TXT文档。
在这里插入图片描述
这时候的压缩包可以正常的解压,不用输入密码

2、将这个正常的压缩包放进winhex里面,看看的是什么效果
在这里插入图片描述

  • 第一个红框的地方是压缩源文件数据区:
50 4B 03 04 是zip头文件标记;

14 00 是解压文件所需要的PK版本;

00 00 是全局方式标记(看是否加密,可以就看第一个00,第二字节00可以忽略。00表示无加密,01表示有加密。不过只要是偶数就是无加密,例如00,02,04等,奇数就是有加密,例如01,03,09等)
  • 接下来的三个红框就是压缩文件目录区,分别为三个文件:
50 4B 01 02 是目录中文件头标记

14 00 压缩使用的 pkware 版本

14 00 解压文件所需 pkware 版本 

 00 00 是全局方式标记(看是否加密,可以就看第一个00,第二字节00可以忽略。00表示无加密,01表示有加密。不过只要是偶数就是无加密,例如00,02,04等,奇数就是有加密,例如01,03,09等)
  • 最后那个红框就是压缩源文件目录结束标志。

接下来制作一个伪加密包

用winHex打开压缩包

修改如下数据,把1和2进行伪加密
在这里插入图片描述
保存后打开压缩包
在这里插入图片描述
发现1和2后面加上了一个星号,表示加密文件。

我们解压时,发现需要输入密码了。
在这里插入图片描述
这就是伪密码了吧,若是遇到压缩包解压需要密码的时候先放在WinHEX中看看是不是伪加密,只要对比两部分的全局方式位标记,若第二部分是09 00,那就把09修改为00就好

或者
使用ZipCenOp去伪加密:

解密命令java -jar ZipCenOp.jar r xxxx.zip         
加密命令java -jar ZipCenOp.jar e xxxx.zip
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值