參考自 看雪學院 - OllyDB入門教學
前言 :
上一篇是使用入門,現在我們開始正式進入如何使用 Ollydbg. 首先我們透過一個簡單的程式, 來示範如何透過 Ollydbg 來破解該程式的密碼輸入. 使用技巧為透過特定字串搜尋快速找到關鍵組碼的位置. 假設我們有程式碼如下 :
編譯完為 VTT.exe 執行檔, 透過 PEiD (Unpack 工具) 可以知道該程式是由哪種編譯器編譯 :
由於這是我們自己寫的範例程式, 並未被 pack 過所以可以直接進行反編譯 (由上可以該程式由 Microsoft Visual C++ 8.0 編譯).
觀察程式行為 :
在開始反編譯之前, 建議可以先觀察一下程式的行為以有助於我們找到一些關鍵點快速進行分析與設定斷點. 故執行程式如下 :
而上可觀察程式的行為 :
好了,今天我們就從這個錯誤訊息中顯示的「Wrong password. try again...」來入手. 啟動 OllyDBG,選取選單 檔案->開啟 載入 VTT.exe 檔案,我們會停在這裡 :
進行反編譯分析 :
首先我們知道程式會需要使用者輸入用戶名, 而在這之前的代碼我們並沒有興趣 (我們有興趣的是密碼!!!!), 因此按下 F9, 則程式會停在等待用戶輸入名字的點 :
接著我們輸入用戶名後再按 Enter, 然後再輸入密碼 123 在按下 Enter, 此時會出現錯誤訊息 'Wrong password. try again...' 並要求再次輸入密碼...
接著我們從錯誤訊息著手, 我們在反編譯視窗中右擊,出來一個選單,然後在 尋找->所有參考文字字串(Search for -> All referenced text strings) 上左鍵點擊 :
會出現下面視窗, 此時我們可以發現裡面有我們要找尋的錯誤提示訊息, 在上面 double click 可以帶我們回到對應組碼的位置 :
回到組碼後, 觀察發現在 0042E816 . E8 42DFFFFF CALL VTT.0042C75D 可能是進行密碼判斷的地方, 因此我們在前一行設斷點. (按 F2)
輸入完斷點後, 我們再次輸入密碼 :
接著會發現 Ollydbg 停在剛剛我們設定的斷點, 接著便是按 F8 一步步執行到 0042E816 CALL VTT.0042C75D 按下 F7 進入呼叫的組語區段 :
進入該區段後, 可以發現在 RETN 之前便是我們找尋驗證密碼的組語內容 :
接著我們來看看這段的組語 :
接著我們按 F8 一步步直到回去原來的呼叫記憶體區段, 並知道當 EAX 為 0 時會進入密碼正確的區段 :
接著既然你知道密碼, 也知道判斷的邏輯, either 你輸入正確的密碼或是在進入 0042E820 JNZ SHORT VTT.0042E835 將 Zero flag 設為 1 都可以成功的破解程式, 到此你已經具備基本的 Ollydbg 使用技巧了. 在這裡你學會如何透過特定字串快速找到需要分析的組碼區段並設定斷點一步步分析觀鍵組碼以達到我們的目的.
This is a blog to track what I had learned and share knowledge with all who can take advantage of them
標籤
- [ 英文學習 ]
- [ 計算機概論 ]
- [ 深入雲計算 ]
- [ 雜七雜八 ]
- [ Algorithm in Java ]
- [ Data Structures with Java ]
- [ IR Class ]
- [ Java 文章收集 ]
- [ Java 代碼範本 ]
- [ Java 套件 ]
- [ JVM 應用 ]
- [ LFD Note ]
- [ MangoDB ]
- [ Math CC ]
- [ MongoDB ]
- [ MySQL 小學堂 ]
- [ Python 考題 ]
- [ Python 常見問題 ]
- [ Python 範例代碼 ]
- [心得扎記]
- [網路教學]
- [C 常見考題]
- [C 範例代碼]
- [C/C++ 範例代碼]
- [Intro Alg]
- [Java 代碼範本]
- [Java 套件]
- [Linux 小技巧]
- [Linux 小學堂]
- [Linux 命令]
- [ML In Action]
- [ML]
- [MLP]
- [Postgres]
- [Python 學習筆記]
- [Quick Python]
- [Software Engineering]
- [The python tutorial]
- 工具收集
- 設計模式
- 資料結構
- ActiveMQ In Action
- AI
- Algorithm
- Android
- Ansible
- AWS
- Big Data 研究
- C/C++
- C++
- CCDH
- CI/CD
- Coursera
- Database
- DB
- Design Pattern
- Device Driver Programming
- Docker
- Docker 工具
- Docker Practice
- Eclipse
- English Writing
- ExtJS 3.x
- FP
- Fraud Prevention
- FreeBSD
- GCC
- Git
- Git Pro
- GNU
- Golang
- Gradle
- Groovy
- Hadoop
- Hadoop. Hadoop Ecosystem
- Java
- Java Framework
- Java UI
- JavaIDE
- JavaScript
- Jenkins
- JFreeChart
- Kaggle
- Kali/Metasploit
- Keras
- KVM
- Learn Spark
- LeetCode
- Linux
- Lucene
- Math
- ML
- ML Udemy
- Mockito
- MPI
- Nachos
- Network
- NLP
- node js
- OO
- OpenCL
- OpenMP
- OSC
- OSGi
- Pandas
- Perl
- PostgreSQL
- Py DS
- Python
- Python 自製工具
- Python Std Library
- Python tools
- QEMU
- R
- Real Python
- RIA
- RTC
- Ruby
- Ruby Packages
- Scala
- ScalaIA
- SQLAlchemy
- TensorFlow
- Tools
- UML
- Unix
- Verilog
- Vmware
- Windows 技巧
- wxPython
訂閱:
張貼留言 (Atom)
[Git 常見問題] error: The following untracked working tree files would be overwritten by merge
Source From Here 方案1: // x -----删除忽略文件已经对 git 来说不识别的文件 // d -----删除未被添加到 git 的路径中的文件 // f -----强制运行 # git clean -d -fx 方案2: 今天在服务器上 gi...
-
前言 : 為什麼程序管理這麼重要呢?這是因為: * 首先,本章一開始就談到的,我們在操作系統時的各項工作其實都是經過某個 PID 來達成的 (包括你的 bash 環境), 因此,能不能進行某項工作,就與該程序的權限有關了。 * 再來,如果您的 Linux 系統是個...
-
屬性 : 系統相關 - 檔案與目錄 語法 : du [參數] [檔案] 參數 | 功能 -a | 顯示目錄中個別檔案的大小 -b | 以bytes為單位顯示 -c | 顯示個別檔案大小與總和 -D | 顯示符號鏈結的來源檔大小 -h | Hum...
-
來源自 這裡 說明 : split 是 Perl 中非常有用的函式之一,它可以將一個字串分割並將之置於陣列中。若無特別的指定,該函式亦使用 RE 與 $_ 變數 語法 : * split /PATTERN/,EXPR,LIMIT * split /...
沒有留言:
張貼留言