孩子还是有一颗网安梦——Bandit通关教程:Level 12 → Level 13

2023-12-15 04:36

本文主要是介绍孩子还是有一颗网安梦——Bandit通关教程:Level 12 → Level 13,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

🕵️‍♂️ 专栏《解密游戏-Bandit》

🌐 游戏官网: Bandit游戏

🎮 游戏简介: Bandit游戏专为网络安全初学者设计,通过一系列级别挑战玩家,从Level0开始,逐步学习基础命令行和安全概念。玩家需通过阅读信息、使用命令和解决问题来完成每个级别。在不清楚时建议查阅手册、使用内建命令或搜索引擎,旨在培养初学者的基本技能。

📖 博客说明: 本系列博客记录个人通关教程,一起探索网络安全的奇妙世界吧! 🚀

零、Level 12 → Level 13

游戏直通车->🚗 🚕 🚙

在这里插入图片描述

一、关卡解读

密码在data.txt文件里,data.txt文件是一个被多次压缩的文件的hexdump。

二、通关教程

首先解释下题目的意思,假设有个文件A,现在将其多次压缩为B,将其执行hexdump命令,得到data.txt文件。

所以,我们需要先反向的执行hexdump命令,得到B文件,然后再反复解压,得到A文件,得到密码。

hexdump命令可以将文件内容以十六进制、十进制、八进制以及ASCII码形式展示:
hexdump一般用来查看“二进制”文件的十六进制编码,所以data.txt文件里面的内容是B文件的十六进制编码:
cat查看data.txt,发现里面数据存在f,表面是十六进制:

在这里插入图片描述

所以,现在就需要先将其还原成二进制编码。查看hexdump命令的官方教程,并没有发现可以逆向的操作。

观察题目,题目中提到一个xxd命令,通过man xxd查看官方教程:

在这里插入图片描述

发现这个命令可以对hexdump文件做逆向操作。

由于游戏服务器权限设置,我们只能在/tmp文件夹中操作。

先随便创建一个属于我们自己的文件夹,/tmp/myownfile:

mkdir /tmp/myownfile

将data.txt复制到刚才创建的文件夹中:

cp data.txt /tmp/myownfile

在这里插入图片描述

cd到/tmp/myownfile中,方便后续操作。

通过xxd命令的-d操作,将十六进制编码文件转换为二进制编码文件:

在这里插入图片描述

执行xxd -b data.txt >> data_2.txt命令,将转换后的二进制编码文件保存到data_2.txt中。

在这里插入图片描述

通过file命令,查看data_2.txt的文件类型:

在这里插入图片描述
但是发现还是ASCII text文件,并不是我们想要的压缩文件。所以很可能是方向错了。

通过重新查看xxd的教程,发现一个-r命令,可以用于逆向hexdump的文件:

在这里插入图片描述
利用 xxd -r data.txt >> data_r.txt将hexdump后的data.txt逆向为data_r.txt,通过file命令,查看到,data_r.txt是gzip文件:

在这里插入图片描述

接下来就可以开始使用gzip命令解压了。

通过查看官方教程(man gzip),找到gzip命令的解压命令:

在这里插入图片描述
尝试解压:

在这里插入图片描述

发现后缀不对,通过cp命令,修改data_r.txt为data_r.gz,再次解压:

在这里插入图片描述

通过gzip -d data_r.gz解压后,data_r.gz变成了data_r。再次执行file命令查看data_r的类型:

在这里插入图片描述

发现现在data_r文件是bzip2类型了,我们修改data_r为data_r.bz2(cp data_r data_r.bz2)。接着,利用bzip2解压bzip2 -d data_r.bz2 -f。解压得到新的data_r文件:

在这里插入图片描述

发现又是一个gzip文件,重复前面的操作,解压。

在这里插入图片描述

这次解压后,是tar压缩文件了,修改后缀为.tar(cp data_r data_r.tar),然后解压(tar -xvf data_r.tar):

在这里插入图片描述
解压得到一个data5.bin文件,继续查看类型:

在这里插入图片描述

依然是tar文件,重复tar解压:

在这里插入图片描述

重复解压,最终得到密码:wbWdlBxEir4CaE8LaPhauuOo6pwRmrDw

在这里插入图片描述

Voila!,恭喜通关🎉🥳~

三、学习资料

推荐一个不错的Linux命令学习网站:Linux Tutorial

👨‍💻 关于我:我是zh4men9,一个曾经有过网安梦的孩子。如果你对我的学习经验和网络安全故事感兴趣,欢迎访问我的CSDN博客:CSDN博客。

📚 更多分享: 你还可以在我的知乎博客上找到我更多的观点和经验分享:知乎博客。

💻 GitHub链接: 如果你对我的项目和代码感兴趣,可以在我的GitHub上找到更多:GitHub链接。

这篇关于孩子还是有一颗网安梦——Bandit通关教程:Level 12 → Level 13的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/495131

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

SWAP作物生长模型安装教程、数据制备、敏感性分析、气候变化影响、R模型敏感性分析与贝叶斯优化、Fortran源代码分析、气候数据降尺度与变化影响分析

查看原文>>>全流程SWAP农业模型数据制备、敏感性分析及气候变化影响实践技术应用 SWAP模型是由荷兰瓦赫宁根大学开发的先进农作物模型,它综合考虑了土壤-水分-大气以及植被间的相互作用;是一种描述作物生长过程的一种机理性作物生长模型。它不但运用Richard方程,使其能够精确的模拟土壤中水分的运动,而且耦合了WOFOST作物模型使作物的生长描述更为科学。 本文让更多的科研人员和农业工作者

沁恒CH32在MounRiver Studio上环境配置以及使用详细教程

目录 1.  RISC-V简介 2.  CPU架构现状 3.  MounRiver Studio软件下载 4.  MounRiver Studio软件安装 5.  MounRiver Studio软件介绍 6.  创建工程 7.  编译代码 1.  RISC-V简介         RISC就是精简指令集计算机(Reduced Instruction SetCom

前端技术(七)——less 教程

一、less简介 1. less是什么? less是一种动态样式语言,属于css预处理器的范畴,它扩展了CSS语言,增加了变量、Mixin、函数等特性,使CSS 更易维护和扩展LESS 既可以在 客户端 上运行 ,也可以借助Node.js在服务端运行。 less的中文官网:https://lesscss.cn/ 2. less编译工具 koala 官网 http://koala-app.

【Shiro】Shiro 的学习教程(三)之 SpringBoot 集成 Shiro

目录 1、环境准备2、引入 Shiro3、实现认证、退出3.1、使用死数据实现3.2、引入数据库,添加注册功能后端代码前端代码 3.3、MD5、Salt 的认证流程 4.、实现授权4.1、基于角色授权4.2、基于资源授权 5、引入缓存5.1、EhCache 实现缓存5.2、集成 Redis 实现 Shiro 缓存 1、环境准备 新建一个 SpringBoot 工程,引入依赖:

Windows环境利用VS2022编译 libvpx 源码教程

libvpx libvpx 是一个开源的视频编码库,由 WebM 项目开发和维护,专门用于 VP8 和 VP9 视频编码格式的编解码处理。它支持高质量的视频压缩,广泛应用于视频会议、在线教育、视频直播服务等多种场景中。libvpx 的特点包括跨平台兼容性、硬件加速支持以及灵活的接口设计,使其可以轻松集成到各种应用程序中。 libvpx 的安装和配置过程相对简单,用户可以从官方网站下载源代码

PHP APC缓存函数使用教程

APC,全称是Alternative PHP Cache,官方翻译叫”可选PHP缓存”。它为我们提供了缓存和优化PHP的中间代码的框架。 APC的缓存分两部分:系统缓存和用户数据缓存。(Linux APC扩展安装) 系统缓存 它是指APC把PHP文件源码的编译结果缓存起来,然后在每次调用时先对比时间标记。如果未过期,则使用缓存的中间代码运行。默认缓存 3600s(一小时)。但是这样仍会浪费大量C

Qt多语种开发教程

Qt作为跨平台的开发工具,早已应用到各行各业的软件开发中。 今天讲讲,Qt开发的正序怎么做多语言开发。就是说,你设置中文,就中文显示;设置英语就英文显示,设置繁体就繁体显示,设置发育就显示法语等。 开发环境(其实多语种这块根环境没太大关系):win10,Qt.5.12.10 一.先用QtCreator创建一个简单的桌面程序 1.工程就随便命名“LanguageTest”,其他默认。 2.在设计师