參考自 看雪學院 - OllyDB入門教學
OllyDBG 的安裝與組態 :
OllyDBG 1.10 版的發佈版本是個 ZIP 壓縮包,只要解壓到一個目錄下,執行 OllyDBG.exe 就可以了。中文化版的發佈版本是個 RAR 壓縮包,同樣只需解壓到一個目錄下執行 OllyDBG.exe 即可. 底下是打開後的視窗配置 :
繁體版可以到下面下載 :
OllyDBG 中各個視窗的功能如上圖. 接著簡單解釋一下各個視窗的功能 :
- 反編譯組語視窗
- 暫存器與旗標視窗
- 追蹤訊息視窗
- 記憶體內容視窗
- 堆疊視窗
啟動後我們要把外掛程式及 UDD 的目錄組態為絕對路徑,點擊選單上的 選項->介面 (Options->Appearance),將會出來一個介面選項的對話框,我們點擊其中的目錄標籤 :
因為我這裡是把 OllyDBG 解壓在 D:\_AV Tools\ollydbg110 目錄下,所以相應的 UDD 目錄及外掛程式目錄按圖上組態。還有一個常用到的標籤就是上圖後面那個字型,在這裡你可以變更 OllyDBG 中顯示的字型。上圖中其它的選項可以保留為預設,若有需要也可以自己修改。修改完以後點擊確定,跳出一個對話框,說我們變更了外掛程式路徑,要重新啟動 OllyDBG。在這個對話框上點確定,重新啟動一下 OllyDBG,我們再到介面選項中看一下,會發現我們原先設定好的路徑都已儲存了。有人可能知道外掛程式的作用,但對那個 UDD 目錄不清楚。我這簡單解釋一下 : 這個 UDD 目錄的作用是儲存你除錯的工作。比如你除錯一個軟體,設定了斷點,加入了注解,一次沒做完,這時 OllyDBG 就會把你所做的工作儲存到這個 UDD 目錄,以便你下次除錯時可以繼續以前的工作。如果不設定這個 UDD 目錄,OllyDBG 預設是在其安裝目錄下儲存這些後綴名為 udd 的檔案,時間長了就會顯的很亂,所以還是建議專門設定一個目錄來儲存這些檔案.
另外一個重要的選項就是除錯選項,可通過選單 選項->除錯設定 (Options->Debugging options) 來組態 :
新手一般不需變更這裡的選項,預設已組態好,可以直接使用。建議在對 OllyDBG 已比較熟的情況下再來進行組態。上面那個異常標籤中的選項經常會在脫殼中用到,建議在有一定除錯基礎後學 脫殼(Unpack) 時再組態這裡.
除了直接啟動 OllyDBG 來除錯外,我們還可以把 OllyDBG 新增到資源管理器右鍵選單,這樣我們就可以直接在 .exe 及 .dll 檔案上點右鍵選取「用Ollydbg開啟」選單來進行除錯。要把 OllyDBG 新增到資源管理器右鍵選單,只需點選單 選項->新增到瀏覽器 (Options->Add to explorer),將會出現一個對話框,先點擊「加入 Ollydbg 到系統資源管理器選單」,再點擊「完成」按鈕即可。要從右鍵選單中移除也很簡單,還是這個對話框,點擊「從系統資源管理器選單移除 Ollydbg」,再點擊「完成」就行了.
OllyDBG 支援外掛程式功能,外掛程式的安裝也很簡單,只要把下載的外掛程式(一般是個 DLL 檔案)複製到 OllyDBG 安裝目錄下的 PLUGIN 目錄中就可以了,OllyDBG 啟動時會自動識別。要注意的是 OllyDBG 1.10 對外掛程式的個數有限制,最多不能超過 32 個,否則會出錯。建議外掛程式不要加入的太多. 到這裡基本組態就完成了,OllyDBG 把所有組態都放在安裝目錄下的 ollydbg.ini 檔案中.
基本除錯方法 :
OllyDBG 有三種模式來載入程式進行除錯,一種是點擊選單 檔案->開啟 (快捷鍵是 F3)來開啟一個可執行檔案進行除錯,另一種是點擊選單 檔案->附加 來附加到一個已執行的進程上進行除錯。注意這裡要附加的程式必須已執行。第三種就是用右鍵選單來載入程式. 一般情況下我們選第一種模式。比如我們選取一個 TTV.exe 來除錯,通過選單 檔案->開啟 來載入這個程式,OllyDBG 中顯示的內容將會是這樣 :
除錯中我們經常要用到的快捷鍵有這些 :
上面提到的幾個快捷鍵對於一般的除錯基本上已夠用了。要開始除錯只需設定好斷點,找到你感興趣的代碼段再按 F8 或 F7 鍵來一條條分析指令功能就可以了.
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 /...
版大您好,我有一個exe壓縮檔,忘記壓縮密碼,可以請您幫忙用od看看嗎??
回覆刪除如果可以請您回覆給我,我並將檔案寄給您好嗎??
david_lin1214@hotmail.com
先跟您說聲謝謝了!!
david