点击上方“码农的后花园”,选择“星标” 公众号
精选文章,第一时间送达
用到的工具
pyinstxtractor.py 拆包(解压)工具,将exe文件解压成一个文件夹
uncompyle6 pyc反编译工具
010EditorEditor 或者其他二进制查看与修改工具,我这里用的010Editor
安装方法
pip install uncompyle6
第一步:解包
python3 pyinstxtractor.py ***.exe # 这里替换成你要反编译的exe文件
# 会生成一个以 exe文件名+_extracted 的文件夹,这个就是解包后的数据
![2aab8d06a2e118a365475cdc359eb538.png](https://i-blog.csdnimg.cn/blog_migrate/b09458df90c02ed51fe801100e18d2a8.png)
第二步:添加头信息
PyInstaller打包后,pyc文件的前8个字节会被抹掉,所以最后要自己添加回去。前四个字节为python编译的版本,后四个字节为时间戳。想要获得编译版本可以查看打包文件里struct的信息
1). 进入文件夹,找到以exe文件名命名的文件(没有后缀),这个就是目的文件
2). 用 010Editor 打开 struct,前八位就是我们想要的信息,将其复制
![c166696c815c640a0a8ded9b9b423393.png](https://i-blog.csdnimg.cn/blog_migrate/deb6ac329cfa3784509787839fdc2164.png)
3). 用 010Editor 打开目的文件我这里是 abc_text,将上一步复制的信息插入到开头
修改前:
![5da2a6e81117cd9c8c4c212e49120cb8.png](https://i-blog.csdnimg.cn/blog_migrate/3da0d73cfb086bba3463c24fbcab377c.png)
修改后:
![240e914b568538134961a4b090743c6a.png](https://i-blog.csdnimg.cn/blog_migrate/c727fb1963d864cc8c1980ac75b5a6bb.png)
4). 将目的文件我这里是 abc_text,添加pyc的后缀
第三步:逆向目的文件.pyc
1). 其实这里已经可以使用了。了解python的都知道pyc是py文件编译后的二进制文件,因此如果想要分析源码还得继续逆向成.py文件
2). uncompyle6逆向pyc文件
uncompyle6 abc_text.pyc > abc_text.py
![e9f372960e7a69c44e52fe74637a73dd.png](https://i-blog.csdnimg.cn/blog_migrate/46521ece6cfebef2ba48628321ac5735.png)
来源:https://www.jianshu.com/p/5871c3dd633b