Python 控制流代碼混淆簡介,加大別人分析你代碼邏輯和流程難度

来源:https://www.cnblogs.com/python0921/archive/2020/04/13/12694280.html
-Advertisement-
Play Games

前言 文的文字及圖片來源於網路,僅供學習、交流使用,不具有任何商業用途,版權歸原作者所有,如有問題請及時聯繫我們以作處理。 作者: 王平 PS:如有需要Python學習資料的小伙伴可以加點擊下方鏈接自行獲取http://t.cn/A6Zvjdun 聊下 Python 的代碼混淆,對 Python 的 ...


 

Python 控制流代碼混淆簡介,加大別人分析你代碼邏輯和流程難度

 

前言

文的文字及圖片來源於網路,僅供學習、交流使用,不具有任何商業用途,版權歸原作者所有,如有問題請及時聯繫我們以作處理。

作者: 王平

PS:如有需要Python學習資料的小伙伴可以加點擊下方鏈接自行獲取http://t.cn/A6Zvjdun

聊下 Python 的代碼混淆,對 Python 的代碼做混淆感覺是不倫不類,但是對於外包項目交付型的,又有一些需要。

混淆的目的就是加大別人分析你代碼邏輯和流程的難度,讓代碼看上去雜亂,邏輯混亂。但是程式要能正常運行。

一般混淆

對 Python 代碼做簡單點混淆的就是變數名/類名/字元串/常量做混淆,把名稱變成很長或者近似。

這類的混淆庫很多,比如 Intensio-Obfuscator 這個庫,這個庫分簡單和複雜混淆,來看下用它的簡單模式來混淆 Python 代碼:

Python 控制流代碼混淆簡介,加大別人分析你代碼邏輯和流程難度

 

左邊是混淆前,右邊是混淆後,只是把變數名方法名混淆並且加長了。

這種簡單混淆的意義不大,字元串和常量都一目瞭然,代碼結構,就靠靜態分析,代碼的脈絡也看得還是清楚。

再複雜一點的混淆就是把關鍵代碼藏起來,和在代碼裡加一些無效代碼。

還是 Intensio-Obfuscator 這個庫的複雜混淆模式,我們來看看:

 

Python 控制流代碼混淆簡介,加大別人分析你代碼邏輯和流程難度

 

右邊初看,貌似不像是 Python 代碼,實際上右邊那串字元串就是左邊的 Python 代碼,只不過是 unicode 碼。 因為 Python 有個內置函數 exec() 可以執行字元串程式,像這樣:

>> exec("1+1")>> 2

我們把這個字元串里的內容列印成 utf8 看看裡面的內容:

Python 控制流代碼混淆簡介,加大別人分析你代碼邏輯和流程難度

 

 

如上圖,它的混淆一是把變數名做得更長,二是代碼裡加了些干擾代碼,看標紅處,原始代碼本來沒有 for 和 if 語句,混淆後的代碼有了。看上去如果要靜態分析這個代碼很困難了,實際如果把變數名重名命和變短後,這部分多餘的 for 和 if 通過靜態分析,還是較容易跳過去。

總結下 Intensio-Obfuscator 庫複雜混淆模式,先是把代碼變數函數名弄得很長,然後是在代碼裡加入了無效代碼,最後是把源代碼壓縮當成一個字元串,用 exec 來執行。

抽象語法樹混淆

上面的混淆方式相對簡單,通過靜態分析就能反混淆出來。更複雜一點的混淆就是控制流混淆。通常程式的執行流程都是很有條理的,控制流混淆就是把程式的執行流程混淆。

比如代碼里多了很多 while for if 乃至 lamdb 語句,把賦值,加減操作,變成位運算等等。讓你通過靜態分析的方式,很難看出代碼的目的和邏輯是什麼。

怎麼做到控制流混淆,要通過抽象語法樹 (AST),通過抽象語法樹,可以做到用程式來修改程式。通過抽象語法樹,可以很精確的知道程式在做什麼操作,這樣就能很精準的修改代碼。

先看一下簡單的通過抽象語法樹來混淆程式的例子,還是拿上面的程式來舉例。

 

Python 控制流代碼混淆簡介,加大別人分析你代碼邏輯和流程難度

 

左邊是混淆前的代碼,後面是混淆後的。這個例子也是把變數名混淆了,然後是把字元串和常量,還有 import 也混淆了。反混淆的難度比上面大了一點,要通過動態調試才知道程式在幹嘛。

什麼是抽象語法樹

見名知意就是把程式抽象成一棵樹,代碼里的語句被拆成了樹上的一個個節點。Python 里有個 AST 模塊就是用來乾這個的,還是上面的源代碼,看下被 AST 拆成節點後是什麼樣。

 

Python 控制流代碼混淆簡介,加大別人分析你代碼邏輯和流程難度

 

 

Python 控制流代碼混淆簡介,加大別人分析你代碼邏輯和流程難度

 

第二張圖就是把第一張圖創建為了抽象語法樹,並且把源代碼按樹的節點列印出來了。

 

紅箭頭標註了,有 Import 節點,Assign 節點, 函數節點, 加法節點等等。這顆樹可以完全表達上述程式。我們可以通過訪問這顆樹,來用程式修改程式。

Python 控制流代碼混淆簡介,加大別人分析你代碼邏輯和流程難度

 

 

自定義一個類,繼承 ast.NodeTransformer ,比如你想訪問字元串,就實現visit_Str這個方法,想訪問 Import 就實現 visit_ImportFrom 這個方法。在實現的方法里,你可以用一些混淆演算法去混淆,(註意只能是混淆,不能改變結果)。這樣就能做到精細化和更複雜的混淆。

有一個 ASTObfuscate 第三方混淆庫就是通過操作 AST 來混淆代碼,不過對程式邏輯流的混淆沒有,要實現更複雜的控制流混淆,要完整實現這顆解析樹。

當然 Python 的代碼混淆更難的話,應該是通過混淆位元組碼,或者把關鍵代碼做成 so 文件,這樣的混淆難度更大。 位元組碼和 so 文件都是彙編指令。


如果你處於想學Python或者正在學習Python,Python的教程不少了吧,但是是最新的嗎?說不定你學了可能是兩年前人家就學過的內容,在這小編分享一波2020最新的Python教程。獲取方式,私信小編 “ 資料 ”,即可免費獲取哦!

 

 
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 同一行為,通過不同的事物,可以體現出來的不同的形態。多態描述的就是這樣的狀態。 定義:是指同一行為,具有多個不同表現形式。 多態的前提 1. 繼承或者實現【二選一】 2. 方法的重寫【意義體現:不重寫,無意義】 3. 父類引用指向子類對象【格式體現】 多態的體現 格式 父類類型 變數名 = new ...
  • 語言 Batch 前言 以前我一直不明白為什麼那麼多應用程式在讀取“文件路徑”作為參數時為什麼總是在正式的“文件路徑”前要加上個“ f”、" d"、" file"以及“ path”之類的引導參數,以為只是純粹的裝帥,或者增加程式使用的代入感,亦或者是便於理解之類的。所以,我寫的程式中也常常會帶一些引 ...
  • 100個不同類型的python語言趣味編程題 實例14:列表轉字典 題目 列表轉換為字典。 程式分析,可用zip()函數 如果你喜歡我的文章,請滑到下方點個推薦再走. 以給我動力哦;轉載請註名出處。然後..請多來做客鴨。 ...
  • 前言 一個Spring Boot 應用偶爾會因為某些原因啟動失敗,此時Spring Boot會友好地輸出類似於這樣一段文字,告訴你發生了什麼,甚至應該採取什麼行動: *************************** APPLICATION FAILED TO START *********** ...
  • 模仿MATLAB構建的底層繪圖庫 廢話不寫了,就直接甩用法咯,有問題留言交流~ 待更新 ...
  • 初學Spring真是傷不起呀,連一個Mybatis的配置都整了一天才弄出來,太不容易了,所以這裡一定要把它記錄下來,防止自已到時候又忘記了,雖然前後經歷了好長時間,但好在磕磕碰碰的弄出來了,也算給自已一點小安慰吧。 其實Mybatis的配置網上的資料真的不要太多,百度一下會找到好多,也許就是因為太多 ...
  • 錯誤記錄:Data too long for column 'xxx' at row 1使用Flask-sqlalchemy操作數據時報錯: "Data too long for column 'chapter_list' at row 1" 在網上找了很久,發現不是編碼問題,也不是字元集的問題。 ...
  • 代碼 1 @Slf4j 2 public class IntegerCompare { 3 public static void doCompare() { 4 5 Integer a = 127; //Integer.valueOf(127) 6 Integer b = 127; //Intege ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...