freeBuf
主站

分类

漏洞 工具 极客 Web安全 系统安全 网络安全 无线安全 设备/客户端安全 数据安全 安全管理 企业安全 工控安全

特色

头条 人物志 活动 视频 观点 招聘 报告 资讯 区块链安全 标准与合规 容器安全 公开课

官方公众号企业安全新浪微博

FreeBuf.COM网络安全行业门户,每日发布专业的安全资讯、技术剖析。

FreeBuf+小程序

FreeBuf+小程序

如何使用FindFunc在IDA Pro中寻找包含指定代码模式的函数代码
2022-06-12 16:15:51
所属地 广西

关于FindFunc

FindFunc是一款功能强大的IDA Pro插件,可以帮助广大研究人员轻松查找包含了特定程序集、代码字节模式、特定命名、字符串或符合其他各种约束条件的代码函数。简而言之,FindFunc的主要目的就是在二进制文件中寻找已知函数。

使用规则过滤

FindFunc的主要功能是让用户指定IDA Pro中的代码函数必须满足的一组“规则”或约束。FindFunc随后将查找并列出满足所有规则的所有函数。

FindFunc会以智能化的形式对规则进行计划和排序,功能概述如下:

1、目前有六条规则可用;

2、代码匹配考虑寻址大小前缀和操作数大小前缀;

3、函数识别模块;

4、性能规则的智能调度;

5、以简单ASCII格式将规则存储/加载到文件;

6、提供了用于实验的单独选项页;

7、通过剪贴板在选项页之间复制规则(格式与文件格式相同);

8、将整个会话(所有选项页)保存到文件;

9、指令字节的高级复制;

工具要求

IDAPro 7.x(7.6+)

Python 3

x86/x64架构

工具下载

FindFunc是一个IDA Pro插件,基于Python开发,而且不需要安装其他的依赖组件包。广大研究人员可以直接使用下列命令将该项目源码克隆至本地:

git clone https://github.com/FelixBer/FindFunc.git

接下来,将项目中的findfuncmain.py文件拷贝到IDA Pro的插件目录中即可。

可用规则

代码模式匹配

mov r64, [r3*2 * 8 + 0x100]

mov r, [r * 8 - 0x100]

mov r64, [r*32 * 8 + imm]

pass

mov r, word [eax + r*32 * 8 - 0x100]

any r64, r64

push imm

push any

搜索给定值(常量)

mov eax, 0x100

mov eax, [0x100]

and al, [eax + ebx*8 + 0x100]

push 0x100

字节模式匹配

11 22 33 44 aa bb cc

11 22 33 ?? ?? bb cc -> ?? can be any byte

高级代码复制

复制所有字节

B8 44332211      mov eax,11223344

68 00000001      push 1000000

66:894424 70     mov word ptr ss:[esp+70],ax

数据将以下列形式复制:

b8 44 33 22 11 68 00 00 00 01 66 89 44 24 70

仅复制非常量值

B8 44332211      mov eax,11223344

68 00000001      push 1000000

66:894424 70     mov word ptr ss:[esp+70],ax

数据将以下列形式复制:

b8 ?? ?? ?? ?? 68 ?? ?? ?? ?? 66 89 44 24 ??

仅复制操作码

B8 44332211      mov eax,11223344

68 00000001      push 1000000

66:894424 70     mov word ptr ss:[esp+70],ax

数据将以下列形式复制:

b8 ?? ?? ?? ?? 68 ?? ?? ?? ?? 66 89 ?? ?? ??

工具运行截图

项目地址

FindFunc:GitHub传送门

# 代码分析 # 代码安全 # 代码检测 # IDA插件
本文为 独立观点,未经允许不得转载,授权请联系FreeBuf客服小蜜蜂,微信:freebee2022
被以下专辑收录,发现更多精彩内容
+ 收入我的专辑
+ 加入我的收藏
相关推荐
  • 0 文章数
  • 0 关注者
文章目录