美文网首页Python测试流程编程-Python
将python打包后的exe还原成py

将python打包后的exe还原成py

作者: 苦海飘摇 | 来源:发表于2021-08-24 16:08 被阅读0次

    用到的工具

    1. pyinstxtractor.py 拆包(解压)工具,将exe文件解压成一个文件夹
    2. uncompyle6 pyc反编译工具
    3. 010Editor 或者其他二进制查看与修改工具,我这里用的010Editor
    # 安装方法
    pip install uncompyle6
    

    第一步:解包

    python3 pyinstxtractor.py ***.exe   #  这里替换成你要反编译的exe文件
    #  会生成一个以 exe文件名+_extracted 的文件夹,这个就是解包后的数据
    
    样例

    第二步:添加头信息

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

    1. 进入文件夹,找到以exe文件名命名的文件(没有后缀),这个就是目的文件

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

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

    修改前:


    样例

    修改后:


    样例
    1. 目的文件我这里是 abc_text,添加pyc的后缀

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

    1. 其实这里已经可以使用了。了解python的都知道pycpy文件编译后的二进制文件,因此如果想要分析源码还得继续逆向成.py文件,

      样例
    2. uncompyle6逆向pyc文件

    uncompyle6 abc_text.pyc > abc_text.py
    
    样例
    样例
    样例

    由于身边没有windows电脑就不演示exe执行效果了

    相关文章

      网友评论

        本文标题:将python打包后的exe还原成py

        本文链接:https://www.haomeiwen.com/subject/gzmdiltx.html