文章目录

  • 一、zip
    • 压缩源文件数据区
    • 压缩源文件目录区
    • 目录结束标识(End of Central Directory Record)
    • zip伪加密
    • 识别真假加密
  • 二、RAR
    • 文件格式
    • 主要攻击方式

一、zip

CTF中的压缩包隐写一般有这样几个套路

1、通过编码转换隐藏信息(common)
比如给出一堆字符或数字,仔细观察为某种进制,将其解码为十六进制,观察其文件头是压缩包或者是其他格式,修改后缀名后解压得flag

2、在文件中隐藏压缩包(图种)
在CTF压缩包隐写中最为常见,多用于在一个文件中隐藏一个压缩包

原理:以jpg格式为例,完整的JPG由FF D8开头,FF D9结束,图片浏览器会忽略FF D9之后的内容,因此可以在JPG文件之后加入其他的文件。

利用foremost,dd或者直接将其修改为压缩包后缀进行提取。
推荐使用foremost,因为foremost还可以分离其他隐藏的文件。
修改为ZIP文件虽然方法简单,但是如果隐写了多个文件时可能会失败。
以前不知道foremost的时候一直是用dd分离的,后边知道了foremost就一直用的foremost。

3、伪加密
原理:ZIP伪加密是在文件头的加密标志位进行修改,进而再次打开文件时被识别为加密压缩包。

ZIP文件主要由三个部分组成:压缩源文件数据区 + 核心目录 + 目录结束标志

压缩源文件数据区

local file header + file data + data descriptor

local file header:文件头用于标识该文件的开始,记录了该压缩文件的信息,
这里的文件头标识由固定值 50 4B 03 04 开头,也是 ZIP 的文件头的重要标志。file data:文件数据记录了相应压缩文件的数据。data descriptor:数据描述符用于标识该文件压缩结束,
该结构只有在相应的 local file header 中通用标记字段的第 3 bit设为 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:扩展记录长度

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 (直到目录结束标识头)


目录结束标识(End of Central Directory Record)

存在于整个归档包的结尾,用于标记压缩的目录数据的结束。每个压缩文件必须有且只有一个结束标识。

50 4B 05 06:目录结束标记
00 00:当前磁盘编号
00 00:目录区开始磁盘编号
01 00:本磁盘上纪录总数
01 00:目录区中纪录总数
59 00 00 00:目录区尺寸大小
3E 00 00 00:目录区对第一张磁盘的偏移量
00 00:ZIP 文件注释长度

zip伪加密

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

如果把第二个加密标记位的00 00改为09 00,打开就会提示有密码:

其实改成09只是举的一个例子,只要末位是奇数,就代表加密,反之,末位是偶数代表未加密。
有时这里是01,也代表加密!不用更改!

识别真假加密

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

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

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

二、RAR

文件格式

RAR 文件主要由标记块,压缩文件头块,文件头块,结尾块组成。

其每一块大致分为以下几个字段:

RAR压缩包的文件头为:52 61 72 21 1A 07 00

其后是标记块(MARK_HEAD),还有文件头(FILE_HEAD)。

更多信息见:http://www.forensicswiki.org/wiki/RAR

主要攻击方式

1、爆破

利用linux下的rarcrack(http://rarcrack.sourceforge.net/)

2、伪加密

RAR 文件的伪加密在文件头中的位标记字段上,用 010 Editor 可以很清楚的看见这一位,修改这一位可以造成伪加密。

3、其他如明文攻击等方法与ZIP相同。

CTF压缩包隐写类(zip、RAR、zip伪加密)相关推荐

  1. ctf图片隐写中改变图片高和宽

    ctf图片隐写中改变图片高和宽 利用工具 Hex Editor Neo将图片进行十六进制分解, 然后我们可以找出该图片的像素高宽,转化成十六进制然后对应找到该像素点所在位置,进行修改即可.

  2. zip格式文件伪加密

    zip格式文件伪加密 实践是检验真理的唯一标准 简介 zip文件是一种压缩文件,可进行加密,也可不加密.而伪加密是在未加密的zip文件基础上修改了它的压缩源文件目录区里的全局方式位标记的比特值,使得压 ...

  3. CTF—图片隐写+数据隐写

    一.[图片隐写] 题目描述: 在实验主机上的C:\Stegano\3目录下提供了一个名为stego的文件, 找到一个形式为flag{word_word_word}的字符串. 预备知识 [TrID] T ...

  4. CTF MISCword隐写简单题学习思路总结(大概率不会持续更新)

    系列文章目录 好复杂的说,懒得列了说 文章目录 系列文章目录 前言 一.反白 二.word自带隐藏字符 三.word文件本质 四.word字体隐写 前言 前几天参加了HNCTF,其中遇到了不少题可以检 ...

  5. CTF 图片隐写之修改图片高宽

                                                 CTF WriteUp                                            ...

  6. CTF 音频隐写 大总结

    赛题概览 Nuit du Hack CTF Qualifications: Here, kitty kitty! 环境 Windows 考察点 WAV音频文件隐写术 Python基础 密码学 工具 A ...

  7. 图片隐写类简单思路介绍

    1.图片+文本隐写 格式:内嵌着txt文本的jpg或者png图片 解决:直接winhex找,如果只是简单的txt文本嵌入,那应该能在最后的位置看到隐藏的明文信息. 或者直接把疑似的图片修改成txt格式 ...

  8. 180214—【CTF】隐写:JPHS

    JPHS 下载移步 信息隐藏软件JPHS适用于JPEG图像,在Windows和Linux系统平台针对有损压缩JPEG文件进行信息加密隐藏和探测提取的工具.软件里面主要包含了两个程序JPHIDE和JPS ...

  9. ctf图片隐写之修改图片高度

    这里的例子是安恒2018年12月赛MISC题目 这里我们用Hex workshop修改png的高度 先看一下png的文件结构 class Chunk { public: DWORD ChunkLen; ...

  10. 压缩包 zip RAR 7z 密码破解常用的几种方法

    01.Zip属性隐藏 我们先从最简单的开始讲起,可能很多人没有去注意文件属性一栏,往往有时候,加密者会把密码放在属性里面,例如下图: 我们可以看到,这个Zip压缩文件的密码就是www.cnblogs. ...

最新文章

  1. 结合ashx来在DataGrid中显示从数据库中读出的图片
  2. document.getElementById()和document.forms[0].submit()
  3. 模拟生态系统-自己编写生命
  4. 第五届工业互联网大数据:配件需求29th方案与代码
  5. java之解析DNS的SRV记录
  6. iptables 学习笔记 二 参数指令
  7. [LintCode] Coins in a Line I Coins in a Line II
  8. golang redis 队列删除图片
  9. 在windows下安装Linux双系统共存不需要改引导(U盘安装版本)
  10. Zabbix:Lack of free swap space on Zabbix server 解决
  11. 7金5银,中国跳水梦之队背后的“黑科技“是什么?
  12. sudo修改文件夹名字_linux
  13. AD(altium designer)15原理图与PCB设计教程(九)——印制电路板的的后续制作
  14. 天梯赛练习集 L2-021 点赞狂魔(25分)含测试点解析
  15. 斐波那契数列求和(递归)
  16. 不可不知的USB2.0/USB3.0/HDMI静电防护方案
  17. 小米4刷android wear,小米手表第四次OTA升级:最强安卓手表迎来全新功能+百款表盘...
  18. 我流泪了。。。。。。。。。
  19. 攻防世界之新手进阶Caeser Cipher
  20. 电子商务门户解决方案(新网互联)

热门文章

  1. 思科路由器 密码设置和恢复
  2. 离开一线三年后,码农们都过上好的生活了吗
  3. vue vuex 挂载_【HAVENT原创】Vue 中使用 Vuex 的几种写法
  4. 如何删除ppt自带背景音乐_ppt模板里自带的背景乐怎么去掉?
  5. 华为计算机复制怎么删,华为电脑复制粘贴快捷键
  6. 生物信息常用网站(数据库)
  7. 用excel打开txt文件
  8. Android Unrecognized Android Studio (or Android Support plugin for IntelliJ IDEA) version ‘202.7660.
  9. 生产执行系统MES架构设计及应用架构
  10. 身为程序猿——谷歌浏览器的这些骚操作你真的会吗