1、IDA脚本编写基础

  IDC是IDA内置的脚本语言,其语法与C非常相似,它是一种解释性语言。

  • 执行方法

    • 在IDA中按SHIFT+F2键会弹出一个对话框,把语句直接写在对话框中,点击run就可被运行。
    • 在菜单栏中File | Script file载入idc文件。

2、IDC语法

  IDC语言可参考C语言,语句以分号结束,注释为//或/**/,但也有很多不同。

  • 2.1 输出(类似C语言中的printf函数)
  • void Message(string format, …);
  • Message(“Hello world!”);
  • Message(“%s\n”, “Hello world!”);

2.2 变量

  IDC中所有变量都被定义成auto类型,会自动进行类型转换,一般类型有整数型、字符串类型、浮点型。

  • 局部变量:auto counter;
  • extern 引入全局变量的声明,extern outsideGlobal;
  • 字符串支持加好连接:auto str = "hello" + "world";
  • 字符串支持分片操作:str1 = str[7:9];

2.3 操作符

  • 许多标准的C语言操作符(+、-、*、/、%、<<、>>、++、--)在IDC同样适用,但复合赋值运算符+=不支持、逗号操作符也不被支持。

2.4 条件

  • if、if else及三目运算符“?:”是支持的,但是switch语句是不支持的。
auto currAddr;
currAddr = ScreenEA();
if (currAddr % )
Message(“%x is odd\n”, currAddr);
else
Message(“%x is even\n”, currAddr);

2.5 循环

  • 循环可以用for、while、do while实现。
auto origEA, currEA, funStart, funEnd;
origEA = ScreenEA();
funStart = GetFunctionAttr(origEA, FUNCATTR_START);
funEnd = GetFunctionAttr(origEA, FUNCATTR_END);
if(funStart == -)
Message(“%x is not part of a functuion\n”), origEA);
for(currEA=funStart; currEA != BADADDR; currEA=NextHead(currEA, funEnd)){
Message(“%8x\n”, currEA);
}

2.6 函数

  • IDC所有函数必须被定义为静态。
  • 函数的声明与C语言不同,不需要指定类型。
  • 函数参数传递中,加上&表示传地址,不加表示传值。
  • return 返回函数输出。
  • 把自己的IDC函数库加入到ida.idc文件中,我们就可以全局使用自己的IDC函数了。
// 例1:
static outputCurrentAddress(){
auto currAddress;
currAddress = ScreeenEA();
Message(“%x\n”, currAddress);
return currAddress;
}
// 例2:
my_func(q, r, s)

2.7 IDC对象

class ExampleClass{
ExampleClass(x, y){
this.x = x;
this.y = y;
}
~ExampleClass(){
}
foo(x){
this.a = this.a + x;
}
} static main(){
ExampleClass ex;
auto ex = ExampleClass(, );
ex.foo();
ex.z = "string" //特点,可随时给对象添加成员
}

2.8 IDC程序

  • 将IDC脚本代码放到一个文件中可永久性保存。
  • #include <文件> 将指定文件包含在当前文件中
  • #define <宏名称> [可选值]
  • #ifdef <名称> 测试宏是否存在
  • #else 与#ifelse共同使用
  • #endif #ifdef的终止符
  • #undef <名称>删除宏定义
#include <idc.idc>
static main(){
// 代码体
}

2.9 IDC错误处理

  • try/catch

2.10 数组

3、有用的IDC函数

  

  

  

  

  

  

  

  

  

  

  

  

  

IDA-IDC脚本编写语法的更多相关文章

  1. linux base脚本编写-自动领取微信红包

    bash脚本编写 语法 变量 定义: your_name = "ABC" 使用: echo $your_name 只读变量 a = "123" readonly ...

  2. 补充1:IDA的脚本IDC语言

    1.IDA脚本的打开与使用: IDA脚本两种语言:IDC(IDC,本地脚本语言)和Python 2.IDC语言介绍 1.IDC变量:IDC是一种松散的语言,没有明确的类型.使用3中数据类型,整数(ID ...

  3. shell(3):文本处理、基本语法和脚本编写

    一.awk.变量.运算符.if多分支 awk:shell编辑器的一种文本处理工具/命令,同grep.sed一样均可解释正则.具体运用下面awk文本处理有详细说明. 变量:分为系统变量和临时变量.变量一 ...

  4. LoadRunner脚本编写(转)

    性能测试工程师要懂代码么?答案是必须的.好多测试员认为在loadrunner中编写脚本很难很牛X ,主要是大多测试人员并未做过开发工作,大学的那点程序基础也忘记的差不多了.还有非计算机专业出身的测试员 ...

  5. shell脚本编写方法

    shell脚本编写就如同一门语言,涉及到运行环境.基本语法.变量定义.函数.参数(系统参数).条件判定.执行流程控制 等等问题. 本文就以下几个方面进行描述: 运行环境: shell  shebang ...

  6. 一个很不错的bash脚本编写教程

    转自 http://blog.chinaunix.net/uid-20328094-id-95121.html 一个很不错的bash脚本编写教程,至少没接触过BASH的也能看懂! 建立一个脚本 Lin ...

  7. shell脚本编写笔记

    包含转载内容,转载自http://wenku.baidu.com/link?url=jtCHxEYzgGve6P64U3JRQRgU6nhpGvqFLLpWu9I2Htq6hi9TGLudRFkk7r ...

  8. linux 脚本编写基础(一)

    1. Linux 脚本编写基础 1.1 语法基本介绍 1.1.1 开头 程序必须以下面的行开始(必须方在文件的第一行): #!/bin/sh 符号#!用来告诉系统它后面的参数是用来执行该文件的程序.在 ...

  9. 批处理bat脚本编写(附详细例子)

                                                        批处理bat脚本编写(附详细例子) 由于在项目开发的过程中经常需要编写bat脚本,而看大牛们编写 ...

随机推荐

  1. magento CURD操作

    查询: $model = Mage::getModel('mynews/mynews'); $collection = $model->getCollection(); $collection- ...

  2. AJPFX总结IO流中的缓冲思想

    缓冲思想   (因为内存的运算速度要远大于硬盘的原酸速度,所以只要降低硬盘的读写次数,就可以提高效率)    1. 字节流一次读写一个数组的速度明显比一次读写一个字节的速度快很多,    2. 这是加 ...

  3. vue 2.0 路由创建的详解过程

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. R in action读书笔记(22)第十六章 高级图形进阶(下)

    16.2.4 图形参数 在lattice图形中,lattice函数默认的图形参数包含在一个很大的列表对象中,你可通过trellis.par.get()函数来获取,并用trellis.par.set() ...

  5. ALTER TABLE - 修改表的定义

    SYNOPSIS ALTER TABLE [ ONLY ] name [ * ] ADD [ COLUMN ] column type [ column_constraint [ ... ] ] AL ...

  6. CAD参数绘制填充(网页版)

    填充是CAD图纸中不可或缺的对象,在机械设计行业,常常需要将零部件剖开,以表现其内部的细节,而这些被剖开的截面会用填充来表示:在工程设计行业,一些特殊的材料或地形,也会用填充来表示. js中实现代码说 ...

  7. du查看文件大小

    du+文件名就可以查看文件大小 du+ -h + 文件名也是查看文件大小,只是-h会将文件大小转换成M,G等格式

  8. 【转】c++数组初始化

    数组初始化列表中的元素个数小于指定的数组长度时,不足的元素补以默认值. 原文:C/C++数组初始化的一些误区 以前我这样初始化一个数组,并自我感觉良好: ] = { }; // 全部初始化为0 这种简 ...

  9. nexus 搭建 maven 私服

    nexus 搭建 maven 私服 本机环境 Win 8 JDK 7 Maven 3.2 Nexus 2.11 版本选择 http://www.sonatype.org/nexus/archivedn ...

  10. 04C#运算符

    C#运算符 运算符分类 与C语言一样,如果按照运算符所作用的操作数个数来分,C#语言的运算符可以分为以下几种类型: l  一元运算符:一元运算符作用于一个操作数,例如:-X.++X.X--等. l  ...