UNCTF-日常训练-reverse-反编译

本文介绍了如何处理Python打包成的EXE文件,通过使用ida、动态调试和pyinstxtractor进行解包。解包后利用010Editor修复pyc文件头并反编译,得到源代码。此外,还提到了uncompyle6工具的安装和使用,解决在kali环境中遇到的问题,成功反编译得到flag。
摘要由CSDN通过智能技术生成

在这里插入图片描述

没有加壳

在这里插入图片描述

IDA打开,没看到啥有用的信息,用动调也没调出啥来。。。

在这里插入图片描述

参考大佬的博客,知道了这是python项目打包成的exe文件,如何打包可以参考
python3项目打包成exe可执行程序

然后又翻了下之前动调的截图,看到这有个调用了python的dll。(之前都忽略了)

在这里插入图片描述

然后就是需要从这个exe中解包得到代码,可以参考Pyinstaller解包

先从GitHub上下载pyinstxtractor

使用方法:

在这里插入图片描述

cmd下进入该目录输入:python pyinstxtractor.py run.exe

在这里插入图片描述

解包后会在该目录下生成一个文件夹,里面有解包出来的几个pyc文件,其中run.pyc就是我们需要的东东,但是这个还不能正常反编译,因为解包出来的pyc文件是缺失文件头的

在这里插入图片描述

用010editor打开struct.pyc和run.pyc,将 run.pyc 的第一行用 struct.pyc的第一行代替。(struct.pyc中第一行有头文件信息,而 run.pyc中没有,所以要加上去)

在这里插入图片描述

在这里插入图片描述

替换后:

在这里插入图片描述

另存为一个pyc文件,就正常反编译了

在这里插入图片描述

直接用python执行就能得到结果:UNCTF{un_UN_ctf123}

#!/usr/bin/env python
# visit https://tool.lu/pyc/ for more information`在这里插入代码片`
str2 = 'UMAQBvogWLDTWgX"""k'
flag = ''
for i in range(len(str2)):
    flag += chr(ord(str2[i]) + i)

print(flag)

除了在线网站反编译,还可以使用uncompyle来进行反编译,GitHub项目:GitHub-uncompyle6

安装方法:

pip install uncompyle6
或者
pip install -i  https://pypi.tuna.tsinghua.edu.cn/simple uncompyle 

在这里插入图片描述

使用方法:

uncompyle test.pyc > test.py

但是我在用的时候出现了错误

在这里插入图片描述

kali中python默认版本也是2.7,也在2.6-3.8里面,但是运行不了,,我也换过默认python版本,还是不行,,就很奇怪,找了一会找到个解决方法uncompyle6-python 3.9报错

在这里插入图片描述

需要给uncompile包添加一个3.9支持:

vim /usr/local/lib/python3.9/dist-packages/uncompyle6/bin/uncompile.py

在最后加上 (3,9),然后保存退出

在这里插入图片描述

然后就能正常反编译了,这里加个 -o是输出文件,用 > 是一样的

在这里插入图片描述

然后运行这个反编译出来的py脚本就行

在这里插入图片描述

最终flag :UNCTF{un_UN_ctf123}

  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ofo300

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值