美文网首页
ZIP伪加密

ZIP伪加密

作者: 违规昵称不予展示 | 来源:发表于2020-06-07 15:16 被阅读0次

ZIP可以,RAR或者其他的不行
首先看看前置知识:
感谢大佬https://blog.csdn.net/u011377996/article/details/79286958

为了方便大家,这里直接复制过来

原理


zip伪加密是在文件头的加密标志位做修改,进而再打开文件时识被别为加密压缩包。

背景


首先,我们来看zip文件头协议。这里以中文资料为证,但是仍然建议大家去http://www.pkware.com 阅读官方文档,虽然英文读起来有些困难。

实例

下面给出西普的一个实例:


image.png

压缩源文件数据区:

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文件的文件头或者加密标志位进行适当修改,那就可能会改变文件的可读性了呗!

测试(一)


亲测例子:先压缩一个1.zip,再用Winhex打开,如下图:


image.png

压缩源文件数据区:

50 4B 03 04:这是头文件标记
14 00:解压文件所需 pkware 版本
00 00:全局方式位标记(有无加密)
08 00:压缩方式
07 76:最后修改文件时间
F2 48:最后修改文件日期
……

压缩源文件目录区:

50 4B 01 02:目录中文件文件头标记(0x02014b50)
1F 00:压缩使用的 pkware 版本
14 00:解压文件所需 pkware 版本
00 00:全局方式位标记(有无加密,这个更改这里进行伪加密,改为09 00打开就会提示有密码了)
08 00:压缩方式
07 76:最后修改文件时间
F2 48:最后修改文件日期
……
如果把第二个加密标记位的00 00改为09 00,打开就会提示有密码:

image.png
image.png
于是乎,这样就达到了zip伪加密的目的,可是这里又有一个疑问了,你可能会问,为什么改成09,而不是其他的数字呢,其实改成09只是举的一个例子,只要末位是奇数,就代表加密,反之,末位是偶数代表未加密(这是我猜想的,具体操作也符合我的猜想,可我不知道这个原理是什么,如果你了解的话,欢迎来分享分享~_

测试(二)

猜想:

既然加密标志位可以修改,那头文件标记位应该也能修改吧,试试咯~:


image.png

把文本区原来显示的PK位的50 4B改成其他数据,再打开zip文件:


image.png
显然,这样也使zip文件不可读!

识别真假加密

无加密

压缩源文件数据区的全局加密应当为00 00
且压缩源文件目录区的全局方式位标记应当为00 00

假加密

压缩源文件数据区的全局加密应当为00 00
且压缩源文件目录区的全局方式位标记应当为09 00

真加密

压缩源文件数据区的全局加密应当为09 00
且压缩源文件目录区的全局方式位标记应当为09 00

image.png

相关文章

  • 破解zip加密文件

    一、zip属性隐藏 查看zip属性注释 二、zip伪加密 Zip伪加密是在文件头的加密标志位做修改,进而再打开文件...

  • zip

    文件头尾,伪加密 文件头50 4B 03 04zip文件头 文件尾也有50 4B的标示zip文件尾 伪加密加密位 ...

  • zip伪加密

    ip伪协议的意思是说本来不需要密码的zip文件然后通过修改标志位,然后就可以达到有密码的效果对吗?但是他实际是没有...

  • ZIP伪加密

    ZIP可以,RAR或者其他的不行首先看看前置知识:感谢大佬https://blog.csdn.net/u01137...

  • 那些CTF中的ZIP问题

    1.消息隐藏 写入zip文件,转码有点恶心 2.伪加密 自己写了个脚本查伪加密 3.图片隐藏压缩包 第一步:分析 ...

  • 11-加密-BugkuCTF之zip伪加密

    一,题目--zip伪加密 题目下载一个flag.zip,里面存放flag.txt,需要输入密码才可以解密 二,分析...

  • zip伪加密破解方法

    一、使用ZipCenOp.jar(需要java环境),在cmd中使用 java-jarZipCenOp.jarrx...

  • misc-压缩包basic

    压缩包出题点 1. 伪加密 对本没有加密的文件通过修改加密位(zip里是deFlag或frFlags,rar里是H...

  • ZIP加密

    伪加密 涨姿势了:zip下载下来是加密的,但是其实可能根本不是加密过的。 50 4B 03 04之后的第六位如果是...

  • ZIP压缩包伪加密

    zip伪加密破解方法 一、使用ZipCenOp.jar(需要java环境),在cmd中使用 成功后压缩包可以直接打...

网友评论

      本文标题:ZIP伪加密

      本文链接:https://www.haomeiwen.com/subject/uujctktx.html