1、常用函数

  ScreenEA()

  获取IDA调试窗口中,光标指向代码的地址。通过这个函数,我们就能够从一个已知的点运行我们的脚本。

  GetInputFileMD5()

  返回IDA加载的二进制文件的MD5值,通过这个值能够判断一个文件的不同版本是否有改变。

2、段

  在IDA中二进制文件被分为了不同的段,这些段根据功能分成了不同的类型(CODE、DATA、STACK、CONST、XTRN)。

  一下的函数用于分析获得各种段信息。

  FirstSeg()

  访问程序中的第一个段。

  NextSeg()

  访问下一个段,如果没有就返回BADADDR。

  SegByName(string SegmentName)

  通过段名字返回段基址,举个例子,如果调用.text作为参数,就会返回程序中代码段的开始位置。

  SegEnd(long Address)

  通过段内的某个地址,获得段尾的地址。

  SegStart(long Address)

  通过段内的某个地址,获得段头的地址。

  SegName(long Address)

  通过段内的某个地址,获得段名。

  Segments()

  返回目标程序中的所有段的开始地址。

3、函数

  循环访问程序中的所有函数,确定函数的范围,是脚本编程中会经常碰到的问题。下面函数对于处理函数非常有用。

  Functions(long StartAddress, long EndAddress)

  返回一个列表,包含了从StartAddress到EndAddress之间的所有函数。

  Chunks(long FunctionAddress)

  返回一个列表,包含了函数片段。每个列表项都是一个元组(chunk start, chunk end).

  LocByName(string FunctionName)

  通过函数名返回函数的地址。

  GetFuncOffset(long Address)

  通过任意一个地址,然后得到这个地址所属的函数名,以及给定地址和函数的相对位移。然后把这些信息组成字符串以

  “名字+位移”的形式返回。

  GetFunctionName(long Address)

  通过一个地址,返回这个地址所属的函数。

4、交叉引用

  找出代码和数据的交叉引用,在分析文件的执行流程时很重要,尤其是当我们分析感兴趣的代码块的时候,盲目的查找无意义字符

  会让你有有一种想死的冲动。IDAPython提供了一大堆函数用于各种交叉引用,最常用的就是下面几种:

  CodeRefsTo(long Address, bool Flow)

  返回一个列表,告诉我们Address处代码被什么地方引用了,Flow告诉IDAPython是否要跟踪这些代码。

  CodeRefsFrom(long Address)

  返回一个列表,告诉我们Address地址上的代码引用何处的代码。

  DataRefsTo(long Address)

  返回一个列表,告诉我们Address处数据被什么地方引用了。常用于跟踪全局变量。

  DataRefsFrom(long Address)

  返回一个列表,告诉我们Address地址上的代码引用何处的数据。

5、Debugger Hooks

  Debugger Hook是IDAPython提供的另一个非常酷的功能,用于Hook住IDA内部的调试器,同时处理各种调试事件。

  虽然IDA一般不用于调试任务,但是当需要动态调试的时候,调用IDA内部调试器还是比外部的会方便很多。使用debugger hook

  之前,先要看一个一个hook类,然后在类里头定义各种不同的处理函数。

  1. class DbgHook(DBG_Hooks):
  2. #Event handler for when the process starts
  3. def dbg_process_start(self, pid, tid, ea, name, base, size):
  4. return
  5. #Event handler for process exit
  6. def dbg_process_exit(self, pid, tid, ea, code):
  7. return
  8. #Event handler for when a shared library gets loaded def
  9. def dbg_library_load(self, pid, tid, ea, name, base, size):
  10. return
  11. #Breakpoint handler
  12. def dbg_bpt(self, tid, ea):
  13. return

  这个类包含了我们在创建调试脚本时,会经常用到的几个调试事件处理函数。安装Hook的方式如下:

  debugger = DbgHook()

  debugger.hook()

  现在运行调试器,hook会捕获所有的调试事件,这样就能非常精确的控制IDA调试器。下面的函数在调试时候非常有用:

  AddBpt(long Address)   ----->    在指定的地点设置软件断点。

  GetBptQty() -------------->    返回当前设置的断点数量。

  GetRegVale(string Register) ---->  通过寄存器名获得寄存器值。

  SetRegValue(long Value, string Register) ---->  设定寄存器的值。

IDAPython学习(二)的更多相关文章

  1. emberjs学习二(ember-data和localstorage_adapter)

    emberjs学习二(ember-data和localstorage_adapter) 准备工作 首先我们加入ember-data和ember-localstorage-adapter两个依赖项,使用 ...

  2. ReactJS入门学习二

    ReactJS入门学习二 阅读目录 React的背景和基本原理 理解React.render() 什么是JSX? 为什么要使用JSX? JSX的语法 如何在JSX中如何使用事件 如何在JSX中如何使用 ...

  3. TweenMax动画库学习(二)

    目录            TweenMax动画库学习(一)            TweenMax动画库学习(二)            TweenMax动画库学习(三)            Tw ...

  4. Hbase深入学习(二) 安装hbase

    Hbase深入学习(二) 安装hbase This guidedescribes setup of a standalone hbase instance that uses the local fi ...

  5. Struts2框架学习(二) Action

    Struts2框架学习(二) Action Struts2框架中的Action类是一个单独的javabean对象.不像Struts1中还要去继承HttpServlet,耦合度减小了. 1,流程 拦截器 ...

  6. Python学习二:词典基础详解

    作者:NiceCui 本文谢绝转载,如需转载需征得作者本人同意,谢谢. 本文链接:http://www.cnblogs.com/NiceCui/p/7862377.html 邮箱:moyi@moyib ...

  7. Quartz学习--二 Hello Quartz! 和源码分析

    Quartz学习--二  Hello Quartz! 和源码分析 三.  Hello Quartz! 我会跟着 第一章 6.2 的图来 进行同步代码编写 简单入门示例: 创建一个新的java普通工程 ...

  8. SpringCloud学习(二):微服务入门实战项目搭建

    一.开始使用Spring Cloud实战微服务 1.SpringCloud是什么? 云计算的解决方案?不是 SpringCloud是一个在SpringBoot的基础上构建的一个快速构建分布式系统的工具 ...

  9. DjangoRestFramework学习二之序列化组件、视图组件 serializer modelserializer

      DjangoRestFramework学习二之序列化组件.视图组件   本节目录 一 序列化组件 二 视图组件 三 xxx 四 xxx 五 xxx 六 xxx 七 xxx 八 xxx 一 序列化组 ...

  10. SpringMVC入门学习(二)

    SpringMVC入门学习(二) ssm框架 springMVC  在上一篇博客中,我简单介绍了一下SpringMVC的环境配置,和简单的使用,今天我们将进一步的学习下Springmvc的操作. mo ...

随机推荐

  1. poj1845 sumdiv (因数的和)

    首先分解质因数,$A^B=p_1^{m_1B}p_2^{m_2B}...p_n^{m_nB}$ 然后的话,它的所有因数的和就是$\prod{(1+p_i^1+p_i^2+...+p_i^n)}$ 用一 ...

  2. HDU6321 Dynamic Graph Matching (杭电多校3C)

    给出一些点集,然后对于每一次要求给出的这些点集里的1,2,3,4,5,6....n/2的匹配数, dp[i][j] 表示到第i次操作里点集为j的匹配数,然后我每次加入一条边u-v,我的状态就是 dp[ ...

  3. centos7安装mha4mysql

    mysql搭建mha需要用的两个rpm包.(manager包和node包) 下载地址:https://download.csdn.net/download/dajdajdajdaj/10603389 ...

  4. Codeforces Round #533 (Div. 2) C.思维dp D. 多源BFS

    题目链接:https://codeforces.com/contest/1105 C. Ayoub and Lost Array 题目大意:一个长度为n的数组,数组的元素都在[L,R]之间,并且数组全 ...

  5. Vue -- 双向过滤器去除html标签

    <div id="box"> <input type="text" v-model="msg | filterHtml"& ...

  6. 【洛谷P2215】上升序列

    题目大意:给定一个长度为 N 的序列,有 M 个询问,每个询问要求输出长度为 L 的上升子序列,若不存在,输出 impossible,若存在,输出下标字典序最小的一个. 题解:考虑到若 L 大于整个序 ...

  7. 【洛谷P1896】互不侵犯

    题目大意:给定 N*N 的棋盘,一共放 K 个国王,一共有多少种方法. 题解: i&i<<1 判断是否每个 1 的位置之间都有 0. i&j<<1 判断 i 中 ...

  8. TestNg 11. 超时测试

    前沿:多久时间没有响应,就是超时. 代码:用timeOut这个属性,超过规定的时间就是fail,不超过就是success package com.course.testng; import org.t ...

  9. mysql中using

    select * from ( SELECT u.utm_source ,count(DISTINCT u.mobile) as new_user -- 登记用户 FROM 表名 u WHERE u. ...

  10. TensorFlow入门学习(让机器/算法帮助我们作出选择)

    catalogue . 个人理解 . 基本使用 . MNIST(multiclass classification)入门 . 深入MNIST . 卷积神经网络:CIFAR- 数据集分类 . 单词的向量 ...