日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python打包exe反编译源码_python的exe反编译

發布時間:2023/12/14 python 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python打包exe反编译源码_python的exe反编译 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

??

驅動人生樣本為python打包的exe文件,嘗試反編譯為py文件。

使用pyinstxtractor.py生成pyc文件。

實際嘗試發現,直接反編譯會報錯

看到前面利用pyinstxtractor.py反編譯的錯誤里有個提示“not a pyinstaller archive”,而用來提取的py腳本叫archive_viewer.py(使用archive_viewer.py要安裝PyInstaller,通過pip install pyinstaller即可安裝)

archive_viewer.py命令 #這里是archive_viewer.py可以使用的命令,這里我們用“X”提取文件 U: go Up one level O : open embedded archive name X : extract name Q: quit

由于用PyInstaller打包后,pyc文件的前8個字節會被抹掉,所以最后要自己添加回去。

前四個字節為python編譯的版本,后四個字節為時間戳。(四個字節的magic number、四個字節的timestamp)

想要獲得編譯版本可以查看打包文件里struct的信息,so這里還是提取出struct這個文件

用16進制編輯器打開struct文件,復制其前8個字節

添加到ii.pyc中

然后使用工具反編譯pyc即可得到py。

**可用uncompyle *.pyc反編譯pyc文件得到py**

直接使用pyinstxtractor.py去提取exe文件中的pyc會報錯,需要去掉簽名信息后再使用pyinstxtractor.py解開

首先去掉exe文件的簽名

查看pyinstaller源碼得知,PyInstaller首先會通過讀取程序最后的數據進行識別,如果是符合格式的才會進行解析(c/Program Files/Python/Python37/Lib/site-packages/PyInstaller/archive/reader.py)

MAGIC是文件末尾開始識別的地方。

pyinstaller2.0是包括MAGIC在內的24個字節長度

pyinstaller2.1是包括MAGIC在內的88個字節長度

\014\013\012\013\016 是8進制,可轉換為16進制查看

使用16進制編輯器打開svchost.exe,從最后向前搜索MEI,找到匹配MAGIC的整個結構。

從MEI開始,選中向后88個字節長度為止,剩下后面部分全都刪掉(刪除格式之后的數據)。

然后就完成了去簽名。

最后直接用pyinstxtractor.py提取即可。這里也需要和之前一樣修復頭部數據,方法和上面一樣。

總結

以上是生活随笔為你收集整理的python打包exe反编译源码_python的exe反编译的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。