欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python exe文件解包方法總結(jié)

 更新時(shí)間:2025年03月18日 09:18:06   作者:大牛軟件開發(fā)  
這篇文章總結(jié)了如何從Python EXE文件中提取和反編譯Python腳本(.pyc文件)的過程,包括使用pyinstxtractor.py或archive_viewer.py進(jìn)行解包,感興趣的小伙伴跟著小編一起來看看吧

注:

除特別說明外,下面使用的python版本均為3.8.6

一、步驟

1. exe → pyc

方法1:pyinstxtractor.py

執(zhí)行python pyinstxtractor.py <待解包文件名> ,如果成功,即可獲得<待解包文件名>_extracted 文件夾。

注:執(zhí)行時(shí)會提示python版本問題,想要正常解包必須使用正確的python版本。

方法2:archive_viewer.py

執(zhí)行python archive_viewer.py <待解包文件名> ,會打印EXE文件中包含的所有文件信息

使用x <文件名>命令將想要提取出的文件提取出來,q 命令退出。

兩者的區(qū)別

方法1可以一次性提取出所有文件,方法2只能逐個(gè)提取文件。但是在個(gè)人使用時(shí),方法2的成功率相對較高??梢韵葒L試用方法1,失敗后用方法2。

2. pyc → py

步驟1獲得的文件是pyc文件,還需要進(jìn)一步反編譯獲得py文件。

注:我遇到過直接獲得py文件的情況,所以在反編譯之前可以先查看一下是不是已經(jīng)成功了。

2.1 pyc文件恢復(fù)

注:最新版pyinstxtractor.py支持自動恢復(fù)pyc,但是經(jīng)實(shí)驗(yàn)不能保證準(zhǔn)確性?;蛘哒f需要使用準(zhǔn)確的python版本才行。

在將python文件打包成exe文件的過程中,會抹去pyc文件前面的部分信息,所以在反編譯之前需要檢查并添加上這部分信息。

抹去的信息內(nèi)容可以從struct文件中獲取:

struct文件:

struct文件

pyc文件:

pyc文件

Q1:需要添加多少字節(jié)?

多個(gè)參考文章中提到的添加字節(jié)數(shù)都不一致,這應(yīng)該與使用的python版本有關(guān)。但是在已知的幾個(gè)例子中,可以看出pyc文件開頭的幾個(gè)字節(jié)與struct文件中的字節(jié)是一樣的。比如說上圖中pyc文件是以E3 00 00 00開頭,而這部分字節(jié)就和struct文件的第二行起始字節(jié)相同。

因此在此例中,需要復(fù)制添加的字節(jié)就是struct文件中第一行的16個(gè)字節(jié)

Q2:添加的方法是什么?

在010editor中,選擇Edit→Insert/Overwrite→InsertBytes,Start Address填0,Size填16。

然后將字節(jié)復(fù)制進(jìn)去即可。

2.2 反編譯

反編譯工具

  • Easy Python Decompiler
    這是一個(gè)GUI界面的可執(zhí)行文件,下載下來直接用就可以,但是并不是每次都能成功,有些magic value不能識別。
  • uncompyle6
    該工具需要使用pip安裝,使用腳本執(zhí)行。成功率較高。

反編譯提示magic value有問題怎么辦?

在上面我們添加的16個(gè)字節(jié)中,前四個(gè)字節(jié)表示的就是magic value,其中前兩個(gè)字節(jié)表示的是python的版本號,一般來說magic value的問題就是版本號有問題,編譯工具沒有識別出來該版本號表示的python版本。

如果使用的是Easy Python Decompiler,那么就可以直接轉(zhuǎn)用uncompyle6了。

如果用的已經(jīng)是uncompyle6,那么需要先看一下它可以識別的版本號都有哪些,這個(gè)信息可以在xdis包的magics.py文件中找到,具體方法如下:

  • 命令行輸入pip install xdis,查看其安裝位置

圖片描述

  • 到該目錄下,打開xdis文件夾下的magics.py文件
  • 確定需要識別的版本號
  • 就是之前添加的16個(gè)字節(jié)的前兩個(gè)字節(jié),此例中為0D42,需要轉(zhuǎn)換為十進(jìn)制,就是3394。
  • 查看magics.py中是否有該版本號。

我這里一開始沒有發(fā)現(xiàn)這個(gè)版本號

圖片描述

我的解決方法

我在谷歌上搜索了int2magic(3394),找到了這個(gè)Github項(xiàng)目。

下載下來,按照介紹進(jìn)行安裝。

在執(zhí)行pip install -e .的時(shí)候,提示我xdisuncompyle6的版本不匹配,于是卸載了uncompyle6,又重新安裝了一次。

目前的版本:xdis 5.0.5 uncompyle6 3.7.4

查看該版本xdismagics.py文件:

圖片描述

可以看到已經(jīng)有3394了。

反編譯:

圖片描述

成功!

注:pyc文件一定要有后綴名pyc,不然會報(bào)錯(cuò)

二、PYZ文件的加密問題

有些時(shí)候在步驟1 exe→pyc的過程中,會出現(xiàn)PYZ中的文件無法正常提?。╝rchive_viewer.py),或者提取出來后顯示encrypted(pyinstxtractor.py)的問題。

這個(gè)問題可以使用參考文章2和3中的方法解決:

PYZ文件加密的密鑰保存在pyimod00_crypto_key文件中,該文件也是一個(gè)pyc文件,可以使用上面介紹的方法進(jìn)行反編譯,然后就可以獲得密鑰:

圖片描述

之后的解密腳本有三個(gè)可供選擇,均在參考文章3中,根據(jù)pyinstaller的版本不同選擇不同的腳本,使用時(shí)需要替換其中的key、header以及待解密文件名和目標(biāo)文件名,執(zhí)行后即可獲得解密后的pyc文件,再使用uncompyle6反編譯即可。

注:這三個(gè)腳本中,第一個(gè)腳本適用于PyInstaller<4.0,使用python2執(zhí)行;第二個(gè)和第三個(gè)腳本適用于PyInstaller≥4.0,使用python3執(zhí)行。

圖片描述

以上就是python exe文件解包方法總結(jié)的詳細(xì)內(nèi)容,更多關(guān)于python exe文件解包的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Python PaddleOCR模型訓(xùn)練及使用超詳細(xì)教程

    Python PaddleOCR模型訓(xùn)練及使用超詳細(xì)教程

    OCR英文全稱是Optical Character Recognition,中文叫做光學(xué)字符識別,是通過掃描等光學(xué)技術(shù)與計(jì)算機(jī)技術(shù)結(jié)合的方式直接從影像中提取各類數(shù)據(jù),省去人工錄入,節(jié)約成本,這篇文章主要介紹了Python PaddleOCR模型訓(xùn)練及使用超詳細(xì)教程,需要的朋友可以參考下
    2024-06-06
  • 利用python畫出AUC曲線的實(shí)例

    利用python畫出AUC曲線的實(shí)例

    今天小編就為大家分享一篇利用python畫出AUC曲線的實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-02-02
  • python 根據(jù)csv表頭、列號讀取數(shù)據(jù)的實(shí)現(xiàn)

    python 根據(jù)csv表頭、列號讀取數(shù)據(jù)的實(shí)現(xiàn)

    這篇文章主要介紹了python 根據(jù)csv表頭、列號讀取數(shù)據(jù)的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Python中使用異常處理來判斷運(yùn)行的操作系統(tǒng)平臺方法

    Python中使用異常處理來判斷運(yùn)行的操作系統(tǒng)平臺方法

    這篇文章主要介紹了Python中使用異常處理來判斷運(yùn)行的操作系統(tǒng)平臺方法,這個(gè)方法比較新穎,,需要的朋友可以參考下
    2015-01-01
  • Django開發(fā)RESTful API實(shí)現(xiàn)增刪改查(入門級)

    Django開發(fā)RESTful API實(shí)現(xiàn)增刪改查(入門級)

    這篇文章主要介紹了Django開發(fā)RESTful API實(shí)現(xiàn)增刪改查(入門級),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-05-05
  • MySQL中表的復(fù)制以及大型數(shù)據(jù)表的備份教程

    MySQL中表的復(fù)制以及大型數(shù)據(jù)表的備份教程

    這篇文章主要介紹了MySQL中表的復(fù)制以及大型數(shù)據(jù)表的備份教程,其中大表備份是采用添加觸發(fā)器增量備份的方法,需要的朋友可以參考下
    2015-11-11
  • 詳解MySQL數(shù)據(jù)類型int(M)中M的含義

    詳解MySQL數(shù)據(jù)類型int(M)中M的含義

    int(M)拆分來說,int是代表整型數(shù)據(jù)那,么中間的M應(yīng)該是代表多少位了,后來查mysql手冊也得知了我的理解是正確的,下面這篇文章小編就來舉例詳細(xì)說明。 文中介紹的很詳細(xì),相信對大家的理解和學(xué)習(xí)很有幫助,有需要的朋友們下面就來學(xué)習(xí)學(xué)習(xí)吧。
    2016-11-11
  • Python實(shí)現(xiàn)的二維碼生成小軟件

    Python實(shí)現(xiàn)的二維碼生成小軟件

    這篇文章主要介紹了Python實(shí)現(xiàn)的二維碼生成小軟件,使用wxPython、python-qrcode、pyqrcode、pyqrnative等技術(shù)和開源類庫實(shí)現(xiàn),需要的朋友可以參考下
    2014-07-07
  • Django讀取Mysql數(shù)據(jù)并顯示在前端的實(shí)例

    Django讀取Mysql數(shù)據(jù)并顯示在前端的實(shí)例

    今天小編就為大家分享一篇Django讀取Mysql數(shù)據(jù)并顯示在前端的實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-05-05
  • Spring異常處理?bug的問題記錄(同一份代碼,結(jié)果卻不一樣)

    Spring異常處理?bug的問題記錄(同一份代碼,結(jié)果卻不一樣)

    這篇文章主要介紹了Spring異常處理?bug的問題記錄(同一份代碼,結(jié)果卻不一樣)的相關(guān)資料,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2025-05-05

最新評論