QQ登录

只需要一步,快速开始

APP扫码登录

只需要一步,快速开始

查看: 6749|回复: 0

[Python] 如何将Python打包后的exe还原成.py

[复制链接]

等级头衔

积分成就    金币 : 2861
   泡泡 : 1516
   精华 : 6
   在线时间 : 1321 小时
   最后登录 : 2025-7-9

丰功伟绩

优秀达人突出贡献荣誉管理论坛元老活跃会员

联系方式
发表于 2021-12-2 10:25:03 | 显示全部楼层 |阅读模式
一、用到的工具
/ X4 Z! ~2 F2 ?
  • pyinstxtractor.py  拆包(解压)工具,将exe文件解压成一个文件夹
  • uncompyle6  pyc反编译工具
  • 010EditorEditor  或者其他二进制查看与修改工具,这里用的010Editor
    * Z9 h4 m5 y' |+ B0 A0 A/ {2 D& D
二、安装方法8 z6 M7 i, d7 z. x% P
pip install uncompyle6
第一步:解包* J( G8 b% ^$ B% F5 A
python3 pyinstxtractor.py ***.exe   #  这里替换成你要反编译的exe文件
* h- D$ ~& g. Y/ D, T# \4 f#  会生成一个以 exe文件名+_extracted 的文件夹,这个就是解包后的数据
1.jpg / a, U4 _1 P9 M
第二步:添加头信息
( W* X+ n9 e. l" _. L       PyInstaller打包后,pyc文件的前8个字节会被抹掉,所以最后要自己添加回去。前四个字节为python编译的版本,后四个字节为时间戳。想要获得编译版本可以查看打包文件里struct的信息7 [6 ]% A5 a+ D2 O
1). 进入文件夹,找到以exe文件名命名的文件(没有后缀),这个就是目的文件
' W' b1 ]) m4 `  s- \ 2.jpg
1 H0 S( m, _+ u  e& \9 O2 [8 H2). 用 010Editor 打开 struct,前八位就是我们想要的信息,将其复制$ r" c% G/ r1 g# o( {
3.jpg
# ]; C0 f% h- X3). 用 010Editor 打开目的文件我这里是 abc_text,将上一步复制的信息插入到开头
& [9 p5 s* [% \! v" p! M4 b修改前:, \7 b( E' ?0 Y) }* O
4.jpg
2 t+ G7 Z8 q, R/ h8 @  P! t修改后:6 `7 l3 z/ ?$ I  w3 c0 k: m5 c: b
5.jpg + Z; h2 s0 [" t7 {' E5 f3 _* u2 q
4). 将目的文件我这里是 abc_text,添加pyc的后缀
6 z& a( f* B& W! ~$ z* M) Z第三步:逆向目的文件.pyc0 A" M( u# n7 Z6 a
1). 其实这里已经可以使用了。了解python的都知道pyc是py文件编译后的二进制文件,因此如果想要分析源码还得继续逆向成.py文件
, w. e; @; N0 Y 6.jpg   H8 Y$ v7 M6 P9 s, ~* E* L  _
2). uncompyle6逆向pyc文件( L& ]7 t/ F/ l$ M5 Q
uncompyle6 abc_text.pyc > abc_text.py
7.jpg 8.jpg
+ z$ \* {7 ~  ^& `0 P1 O# p5 f 9.jpg & W0 u6 `# Y' z" c* k2 ~
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|paopaomj.COM ( 渝ICP备18007172号|渝公网安备50010502503914号 )

GMT+8, 2025-8-23 22:56

Powered by paopaomj X3.5 © 2016-2025 sitemap

快速回复 返回顶部 返回列表