base64stego的writeup

本文详细介绍了如何通过分析一个加密的压缩包,利用WinHex工具和自定义Python脚本,成功提取并解码隐藏在Base64编码中的信息,最终获取到flag:Base_sixty_four_point_five。
部署运行你感兴趣的模型镜像

    大家好,这次我为大家带来攻防世界misc部分base64stego的writeup。
    先下载附件,是一个压缩包,用WinRAR查看一下,发现压缩包被加密了。

在这里插入图片描述

    由于这道题没有任何关于压缩包解压密码的提示,暴力破码也肯定不现实,因此我们想到这会不会是一个伪加密。用winhex打开一看,果然如此。

在这里插入图片描述

    将蓝色标记处的9改为0并保存即可。解压文件后找到一个TXT文档,打开发现密密麻麻的字符。结合题目猜测这是base64编码,直接解码无疑是不行的。这是想到这可能是base64隐写。所谓base64隐写,就是依据每一串base64编码末尾可能存在的等号进行隐写,具体请大家自己查阅百度。
    然后我写了一个python脚本将隐藏的二进制编码提取出来并且转为字符。

def base64_decode(strings):
    aaa = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"
    if strings[-2] == "=":
        strings1 = bin(aaa.find(strings[-3]))[2:].zfill(10)
        strings1 = strings1[-4:]
    else:
        strings1 = bin(aaa.find(strings[-2]))[2:].zfill(10)
        strings1 = strings1[-2:]
    return strings1
path = input("输入TXT文档所在的文件夹")
filename = input("输入TXT文档名")
f = open(path + "\\" + filename + ".txt", "r")
bb = ""
for line in f.readlines():
    base64 = line.strip()
    if base64[-1] == "=":
        bb += base64_decode(base64)
i = 0
b = ""
flag = "" 
while i <= len(bb) - 1:
    b += bb[i]
    if i % 8 == 7:
        flag += chr(int(b, 2))
        b = ""
    i += 1
f = open(path + "\\" + "result.txt", "w")
f.write(flag)

    运行之后flag就出来了,flag:Base_sixty_four_point_five 。

您可能感兴趣的与本文相关的镜像

Python3.8

Python3.8

Conda
Python

Python 是一种高级、解释型、通用的编程语言,以其简洁易读的语法而闻名,适用于广泛的应用,包括Web开发、数据分析、人工智能和自动化脚本

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值