逆向學習-IDApython(一)

背景

IDAPython 由三個分離的模塊組成,他們分別是 idc,idautils 和 idaapi。

idc(注意大小寫,不是 IDA 中的 IDC)是一個封裝了 IDA 的 IDC 的兼容性模塊,idautils 是 IDA 的高級實用功能模塊,idaapi 允許了我們訪問更加底層的數據。

基本操作

idc.Screen或者here()返回此時的地址,返回值是一個十進制數,所以可以寫成hex(here())。MaxEA()和MinEA()代表最大值和最小值。

idc.SegName(here())獲取當前地址所在的段的名稱。

idc.GetDisasm(here())獲取當前地址的反匯編語句。

?

IDAPython 的強大之處在于它能遍歷所有的指令,所有的交叉引用地址,還有搜索所有的代碼和數據。

for i in idautils.Segments():

  print idc.SegName(i), idc.SegStart(i), idc.SegEnd(i)

idautils.Segments()返回一個可迭代的對象數組,包含的元素是每個段的起始地址。

獲取段的名稱(idc.SegName(ea)),段的起始地址(idc.SegStart(ea)),段的結束地址(idc.SegEnd(ea))。通過 idc.NextSeg(ea)我們可以獲取到當前地址所在段的下一個段的起始地址 。如果我們想通過名字得到一個段的起始地址,我們可以使用 idc.SegByName(segname)。

函數

遍歷所有段中的所有函數。

idautils.Functions()將會返回一個保存著已知函數首地址的數組。idc.GetFunctionName(ea)返回ea地址處的函數名稱。

?

利用 idaapi.get_func(ea)這個函數來獲取函數的邊界地址(起始和結束地址)

idaapi.get_func(ea)返回一個 idaapi.func_t 的類給我們,有時候你并不清楚這個類能夠干嘛,所以你可以使用 dir(class)函數來獲取這個類究竟有哪些屬性可以使用。

idc.NextFunction(ea) 和idc.PrevFunction (ea)來獲取當前函數的前一個或者后一個函數。

?

轉載于:https://www.cnblogs.com/whitehawk/p/10803489.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/386894.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/386894.shtml
英文地址,請注明出處:http://en.pswp.cn/news/386894.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

RUNOOB python練習題 39 數組排序

用來練手的python練習題,原題鏈接: python練習實例39 題干: 有一個已經排好序的數組。現輸入一個數,要求按原來的規律將它插入數組中。 這個題目用列表List的sort,append方法非常簡單,如下: 想要升序排列的話,就直接…

IIS 部署asp.net Provisional headers are shown 在VS2005返回值,部署不返回值

IIS 部署asp.net Provisional headers are shown 在VS2005調試返回值,部署到IIS不返回值 首先當時為了跨域的問題,在上面 后來把跨域的內容放在IIS去解決 其次,在每次返回結束的時候,加一句話 Response.End();

背包

學習博客https://www.cnblogs.com/fengziwei/p/7750849.html //為了不誤導初學者,和給老手diss的機會,我就把以前發的刪了, 有興趣的看看那個博客就行了 (明明寫好了,卻被老師關機子...不開心轉載于:https://www.cnblo…

POSIX線程

POSIX線程 標簽(空格分隔): Linux程序設計 什么是線程 線程是一個進程內部的一個控制序列。 當在進程中創建一個新線程時,新的執行線程將擁有自己的棧(因此也有自己的局部變量),但與它的創建者共…

RUNOOB python練習題44

用來練手的python練習題,原題鏈接:python練習實例44 題干: 兩個 3 行 3 列的矩陣,實現其對應位置的數據相加,并返回一個新矩陣 使用基本的List類寫起來就比較麻煩,需要初始化一個3*3的全0矩陣,之后通過遍歷將矩陣對應…

ImportError: No module named 'matplotlib'(python 安裝各種 )

matplotlib 怎么弄啊 我應該是安裝matplotlid了的 怎么還說我沒有 編輯于:2017.03.22 12:28 0 分享 |評論0|收藏0|瀏覽7261 qq_37926784 聲望: -4 3個回答 按贊數排序 用pip 也顯示已經安裝了matplotlib 編輯于:2018.03.26 19:43 分…

QBXT Day 5圖論相關

圖論是NOIP的一個非常重要的考點,換句話說,沒有圖論,NOIP的考綱就得少一大半(雖然很NOIP沒有考綱) 圖論這玩意吧,和數論一樣是非常變態的東西,知識點又多又雜,但是好在一個事&#x…

RUNOOB python練習題47 交換兩個變量值

用來練手的python練習題,原題鏈接: python練習實例47 題干: 兩個變量值互換 在C語言C中我們要構造一個能交換兩個變量值的函數很方便,我們可以使用指針,或者C中的引用。那么在沒有指針的python中如何構造一個可以交換兩個變量值的函數呢&am…

tensorflow一元二次函數擬合

先看下要做的內容,創建一元二次函數yx平方-0.5,其中為了更符合散點圖模擬需要,在方程加噪點,以標準方差0.05行駛,如圖所示 折線圖 散點圖 下面我們要做的,是要計算機自動擬合出該散點圖的函數&#xff0…

hibernate緩存機制與N+1問題

在項目中遇到的趣事 本文基于hibernate緩存機制與N1問題展開思考&#xff0c; 先介紹何為N1問題 再hibernate中用list()獲得對象&#xff1a; 1 /**2 * 此時會發出一條sql&#xff0c;將30個學生全部查詢出來3 */4 List<Student> …

lambda函數 RUNOOB python練習題49

用來練手的python練習題&#xff0c;原題鏈接python練習實例49 該練習題主要是關于lambda函數的使用方法&#xff0c;本文就python中的lambda函數做出一點總結。 1. lambda函數的定義與調用 在python中&#xff0c;我們都知道使用def關鍵詞來定義一個函數, 例如一個最簡單的…

kubernetes(k8s)安裝部署

Kubernetes是一個開源的&#xff0c;用于管理云平臺中多個主機上的容器化的應用&#xff0c;Kubernetes的目標是讓部署容器化的應用簡單并且高效,Kubernetes提供了應用部署&#xff0c;規劃&#xff0c;更新&#xff0c;維護的一種機制。 Kubernetes一個核心的特點就是能夠自主…

react typescript 子組件調用父組件

//父組件 import * as React from reactimport { Input } from antdconst Search Input.Searchimport "./index.less"import Child from "./compon/list" interface IProps { MakeMoney?: () > void //暴露方法} export default class ProjectLis…

python random隨機數 RUNOOB python練習題50

用來練手的python練習題&#xff0c;原題鏈接: python練習實例50、 該練習題主要包含了random模塊隨機數的應用&#xff0c;下面給出幾個常用的模塊內函數。 1. 生成浮點型隨機小數 最簡單的&#xff0c;就是用random函數&#xff0c;生成 [0.0,1.0)[0.0, 1.0)[0.0,1.0)范圍…

Spring Cloud Eureka Consul使用和對比

Spring Cloud簡介 最大的區別是Eureka保證AP, Consul為CP。 Consul強一致性(C)帶來的是&#xff1a; 服務注冊相比Eureka會稍慢一些。因為Consul的raft協議要求必須過半數的節點都寫入成功才認為注冊成功 Leader掛掉時&#xff0c;重新選舉期間整個consul不可用。保證了強一致…

符號 RUNOOB python練習題 51

用來練手的python練習題&#xff0c;原題鏈接: python練習實例51 python中的 & 和 | 使用過程中&#xff0c;變量類型不同&#xff0c;這兩個符號的作用也不同。 1. 對于數字變量&#xff0c;&\&& 和 ∣|∣ 用于逐位運算 # 二進制逐位邏輯與門運算 a 0b110…

Eclipse里的快捷鍵

MyEclipse 快捷鍵1(CTRL) ------------------------------------- Ctrl1 快速修復 CtrlD: 刪除當前行 CtrlQ 定位到最后編輯的地方 CtrlL 定位在某行 CtrlO 快速顯示 OutLine CtrlT 快速顯示當前類的繼承結構 CtrlW 關閉當前Editer CtrlK 快速定位到下一個 CtrlE 快…

Python打印楊輝三角形 RUNOOB python練習題61

用來練手的python練習題&#xff0c;原題鏈接: python練習實例61 題干: 打印出楊輝三角形 1 1 1 1 2 1 1 3 3 1 1 4 6 4 1 1 5 10 10 5 1 1 6 15 20 15 6 1 1 7 21 35 35 21 7 1 1 8 28 56 70 56 28 8 1 1 9 36 84 126 126 84 36 9 1 實現代碼如下: import numpy as nptable…

使用Docker快速搭建Tensorflow開發環境

當我剛開始學習使用scikit-learn時&#xff0c;總是會出現各種各樣的包依賴問題&#xff0c;兜兜轉轉了一遍才全部安裝好&#xff0c;現在的機器學習算法開發者大都使用tensorflow、pytorch來實現自己的想法&#xff0c;但依然會面臨各種包版本和依賴的問題&#xff0c;有一段時…