百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

如何使用Kali Linux中的zip2john工具

ahcoder 2024-12-28 10:48 9 浏览

Kali Linux平台中,提供了网络安全渗透测试和密码破解领域的各种强大工具,其中zip2john 是被用来从加密的ZIP文件中提取密码散列的工具,一般情况下,配合John the Ripper(简称 John)使用,用于破解ZIP文件的密码。

下面我们就来详细介绍一下如何在Kali Linux中安装使用zip2john工具。

zip2john的基本原理

Zip文件的加密是将密码作用于文件的内容中,从而形成一个加密的Zip文件。而zip2john工具就是通过解析Zip文件提取出密码的散列Hash值,然后将其转换成能够被John the Ripper工具识别的格式,然后我们就可以通过john工具来进行暴力破解或者是我们可以通过密码字典对其进行暴力破解了。

这里我们先来了解一下zip2john的帮助内容,zip2john是在Kali系统中预装的工具,我们可以通过如下的命令来查看帮助文档。

zip2john --help

会看到如下的结果。

当然如果系统中没有安装对应的工具,我们也可以通过如下的方式来安装。

sudo apt update
sudo apt install john -y

zip2john的使用步骤

我们可以尝试创建一个加密的ZIP文件,然后再实际操作的过程中,我们可能需要对一个未知密码的ZIP加密文件进行破解,这里先来简单的创建爱你一个加密文件。

zip -e file.zip flag.txt
  • -e:表示启用加密。
  • file.zip:表示输出 ZIP 文件名。
  • flag.txt:表示在ZIP文件包含的内容。
  • 使用zip2john提取散列

    接下来我们就用zip2john命令来提取密码的hash散列值。

    zip2john file.zip >> password.txt

    会看到如图所示的散列结果。

    接下来我们就来观察一下生成的password的内容。

    file.zip/flag.txt:$pkzip$1*1*2*0*36*28*8254e3af*0*26*8*36*b306*83e89c350787a6ede68403409c4e16e10767c68936f5f56529e5bfe2146376f20bf7840fde98da30276239e502d20b67c02e2fc242d8*$/pkzip$:flag.txt:file.zip::file.zip

    接下里我们需要通过John工具来对其进行破解了。

    使用 John 破解密码

    这里我们没有现成的密码字典,所以采用没有密码字典的方式进行爆破。

    john password.txt

    当然,如果我们有密码字典的话,可以通过如下的命令来通过密码字典来进行破解。

    john --wordlist=/path/to/wordlist.txt hash.txt
    • --wordlist:指定密码字典。
    • hash.txt:包含提取散列的文件。

    破解成功之后,我们就可以看到ZIP文件的密码为

    20170925         (file.zip/flag.txt)  

    这样我们就可以解密该压缩文件了,当然如果该密码已经被破解了,那么在我们的home目录下会生成一个默认的.john的文件目录,这个时候,我们就可以通过如下的命令来查看已经被破击的文件密码是什么。

    john --show password.txt

    使用技巧与常见问题

    在使用zip2john进行ZIP文件密码破解的时候,为了提高破解的效率,我们可以采用一些高质量的密码字典,例如https://github.com/brannondorsey/naive-hashcat/releases,另外就是大家也发现了笔者这里破解的其实是一个CTF比赛题目的ZIP目的是为了找到压缩文件中的Flag值。所以只是讲解一般的工具使用步骤。

    zip2john工具只支持了一些比较经典的PKZIP和AES-256加密的散列提取,所以对于其他的加密方式可能不支持。

    总结

    zip2john是渗透测试过程中用来处理ZIP文件密码保护的利器。与John the Ripper配合使用,可以高效地提取和破解密码。本篇文章主要介绍的就是如何熟悉的使用工具的工作流程和优化技巧,帮助初学者更好的在实际工作中使用它,当然最后就是免责声明,本文笔者演示如何破解CTF比赛试题,切勿用作非法用途。

    相关推荐

    Linux 6.15将更新媒体子系统:高通Iris驱动首次亮相

    IT之家3月24日消息,科技媒体phoronix昨日(3月23日)发布博文,报道称Linux6.15内核将于本周启动合并窗口,首批提交的PullRequest请求之一,就...

    Ubuntu 25.04发行版登场:Linux 6.14内核,带来多项技术革新

    IT之家4月18日消息,科技媒体linuxiac昨日(4月17日)发布博文,报道称代号为PluckyPuffin的Ubuntu25.04发行版正式上线,搭载最新Linu...

    WordPress 6.8 版本发布:聚焦性能升级,代号“Cecil”

    WordPress6.8版本发布:聚焦性能升级,代号“Cecil”全球最受欢迎的内容管理系统(CMS)WordPress正式推出最新版本6.8,代号“塞西尔”(Cecil),以此致敬传奇钢琴家...

    Linus Torvalds接受微软Hyper-V升级 下一代Linux启动会更快

    虽然Windows的粉丝和Linux的粉丝经常喜欢进行激烈的键盘大战,但操作系统的制造商们自己也了解彼此的优缺点。毫无疑问,微软也明白这一点,事实上,它甚至鼓励用户尝试Linux,尽管是使用...

    Debian 12发布:Linux内核升级6.1(debian更新内核)

    IT之家6月11日消息,Debian是最古老的GNU/Linux发行版之一,也是许多其他基于Linux的操作系统的基础,包括Ubuntu、Kali、MX和树莓派OS等。这...

    Linux Mint预告新功能:升级Nemo搜索、LMDE 7支持OEM安装

    IT之家4月10日消息,LinuxMint发布了最新月度简讯,宣布增强Nemo文件管理器的文件搜索功能、Cinnamon桌面环境开始支持Wayland、LMDE7(LinuxM...

    Linux 6.2合并大量网络系统更新:推进Wi-Fi 7和800 Gbps网络

    IT之家12月15日消息,Linux6.2合并窗口期内已经确认将会合并大量网络子系统更新。和以往版本相同,Linux6.2内核更新周期在网络功能上有大量的改进,更多的细节可以访问这条...

    Linux内核升级实践指南(linux内核怎么升级)

    Linux内核升级是一个需要谨慎操作的过程,但掌握正确方法后可以显著提升系统性能、安全性或硬件兼容性。以下是一份详细的实践指南,涵盖主流方法及注意事项:一、准备工作查看当前内核版本bashuname...

    Linux又将迎来大版本更新 5.20版可能会被称为Linux 6.0

    如果你错过了昨天Linux5.19的发布公告,那么这一消息需要回顾一下:被称为Linux5.20的开发中的内核很可能会被称为Linux6.0。根据LinusTorvalds对现代版本的划分,L...

    周六的娱乐就是安装一台OracleLinux虚拟机(一)

    每个人有每个人的娱乐方式。老父亲可能喜欢摆弄一些机械工具修修补补。我趁着周六安装一套OracleLinux,寓学于乐。在oracle网站上,下载VirtualBox,现在最新版本是7.0.8。在安装过...

    Linux系统下Gaussian 16的安装(linux系统如何安装新软件)

    Gaussian是目前使用最多的量子化学计算软件,当前最新的版本为Gaussian16C.01。理论上来说Gaussian并不需要安装,因为高斯一般是不出售源代码的,只有二进制文件,以Gaussi...

    「Linux基础」VMWare虚拟机安装CentOS后配置静态ip

    在VMWare中安装本地虚拟机CentOS7操作系统,动态IP地址会经常变化,不便于管理与实验。为了便于实验,考虑设置成静态IP地址,目标是本地局域网可以通过NAT网关互相访问,且能连接互联网。由于是...

    Win10虚拟机,Hyper-V安装CentOS,一次成功

    打开控制面板,选择程序选择启用或关闭Windows功能选中Hyper-V下所有的组件。提示我们需要,重启计算机,保存我们的文件,之后点击“立即重新启动”选择开始菜单,输入Hy,就可以打开虚拟机管理器了...

    如何在Windows 10中的Hyper-V虚拟机上安装CentOS Linux

    注意双重引导的一种可行且相当不错的替代方法是在虚拟机上安装各种操作系统。Microsoft正式支持CentOS作为Hyper-V的来宾OS,并且在安装时可以很好地集成。自CentOS6.4版以来,用...

    安装Linux虚拟机的5个理由,以及不安装的5个原因

    虚拟机(VM)允许你在不永久更改计算机的情况下探索Linux。如果你对Linux很好奇,但犹豫是否要尝试,VM提供了一个安全、灵活的解决方案。如果这是你第一次听说虚拟机,虚拟机就像“计算机中的计算机”...