如果使用python写了程序,有时候希望将程序打包成一个应用程序,如exe,这时候可以使用pyinstaller,来打包应用程序。
可以使用pip安装:
pip install pyinstaller
如果是使用pycharm平台,可以使用上面的pip安装,也可以直接插件安装:
安装好pyinstaller插件后,使用:
pyinstaller yourprogram.py
来打包你的程序。
输入指令,就开始自动打包,最后可以在输出文件夹里看到生成的main.exe文件:
上面就是打包的过程。
如果现在没有源程序,想要通过这个exe来反编译,就需要用到另一个插件:
pyinstxtractor.py
下载地址:https://sourceforge.net/projects/pyinstallerextractor/
下载好后,将这个程序与需要解包的exe程序放到一个文件夹。
pyinstxtractor.py的使用也很简单,在python的命令行终端或者pycharm的终端,进入当前文件夹:
这时候反编译第一步就完成了:
这里生成的应该是pyc文件,但这里需要进行一些手动的修改,然后进行下一步,也就是对.pyc文件再进行反编译。
自己测试了一下,也实现了,所以把后续步骤也写一下:
在利用pyinstxtractor.py反编译后,可以看到文件夹里出现了:main、struct这两个没有后缀的文件,这个main其实就是python的main,但是因为里面少了一些东西,所以需要打开这个main并添加上。这里需要用到另一个软件:010 editor
下载地址:https://www.sweetscape.com/010editor/
这个软件是收费软件,但是可以试用30天。
安装好010editor后,打开软件:
然后在软件中分别打开main和struct文件:
仔细看这两个文件的信息,可以发现,main的第一行字节数据和struct的第二行一样,也就是struct比main多了前面一行也就是16个字节的数据(这个数量有可能不一样,以实际文件内容为准,也有可能是12个字节或者更少)。关于这个数据的内容的解释,可以去看一下网上其他更专业的解释,这边就不多说了(本人也不是很懂)。
将struct的第一行复制,然后再main这边插入到第一行前面,具体操作:010editor软件菜单栏的Edit,在下拉菜单中找到Insert/overwrite,然后选择insert bytes,设置首地址为0,长度为16(按自己的实际来写)。
点击insert,就会在main插入一行空字节,然后选中第一行,将struct的第一行copy覆盖过来。完成点击保存,并将main保存成main.pyc文件,然后你就会在文件夹里看到:
这个就是main.pyc文件了。
接下来要将main.pyc还原成main.py,我看网上说可以用uncompyle6,但我实际测试了,这个模块支持py2.7-3.8,如果你用的是最新的3.9,用uncompyle6就不行。
有一种在线反编译工具:
图片中的程序就是我用pycharm写的,的确是完全反编译过来,不过,这个在线工具有时候也会编译不出来:
基本上利用这样的一个流程,应该是能反编译一个使用python写的且打包成exe格式的程序的。