首页 编程技术将python打包后的exe还原成py

将python打包后的exe还原成py

运维派隶属马哥教育旗下专业运维社区,是国内成立最早的IT运维技术社区,欢迎关注公众号:yunweipai
领取学习更多免费Linux云计算、Python、Docker、K8s教程关注公众号:马哥linux运维

用到的工具

  1. pyinstxtractor.py 拆包(解压)工具,将exe文件解压成一个文件夹

  2. uncompyle6 pyc反编译工具

  3. 010EditorEditor 或者其他二进制查看与修改工具,我这里用的010Editor

安装方法

pip install uncompyle6

第一步:解包

python3 pyinstxtractor.py ***.exe   #  这里替换成你要反编译的exe文件

#  会生成一个以 exe文件名+_extracted 的文件夹,这个就是解包后的数据

将python打包后的exe还原成py插图

第二步:添加头信息

PyInstaller打包后,pyc文件的前8个字节会被抹掉,所以最后要自己添加回去。前四个字节为python编译的版本,后四个字节为时间戳。想要获得编译版本可以查看打包文件里struct的信息

1). 进入文件夹,找到以exe文件名命名的文件(没有后缀),这个就是目的文件
将python打包后的exe还原成py插图1

2). 用 010Editor 打开 struct,前八位就是我们想要的信息,将其复制

将python打包后的exe还原成py插图2

3). 用 010Editor 打开目的文件我这里是 abc_text,将上一步复制的信息插入到开头

修改前:

将python打包后的exe还原成py插图3

修改后:

将python打包后的exe还原成py插图4

4). 将目的文件我这里是 abc_text,添加pyc的后缀

第三步:逆向 目的文件.pyc

1). 其实这里已经可以使用了。了解python的都知道pyc是py文件编译后的二进制文件,因此如果想要分析源码还得继续逆向成.py文件将python打包后的exe还原成py插图5

2). uncompyle6逆向pyc文件

uncompyle6 abc_text.pyc > abc_text.py

将python打包后的exe还原成py插图6

将python打包后的exe还原成py插图7
将python打包后的exe还原成py插图8

本文链接:https://www.yunweipai.com/40545.html

网友评论comments

发表回复

您的电子邮箱地址不会被公开。

暂无评论

Copyright © 2012-2022 YUNWEIPAI.COM - 运维派 京ICP备16064699号-6
扫二维码
扫二维码
返回顶部