前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Karta:一款功能强大的IDA源代码辅助插件

Karta:一款功能强大的IDA源代码辅助插件

作者头像
FB客服
发布2021-11-16 10:21:02
1.1K0
发布2021-11-16 10:21:02
举报
文章被收录于专栏:FreeBuf

关于Karta

Karta是一款功能强大的IDA Python插件,该工具可以识别并匹配给定代码中的开源代码库。该插件使用了一种独特的技术,使其能够支持大型二进制文件(>200000个函数),而同时几乎不会影响整体性能。

Karta所使用的匹配算法是位置驱动的,这意味着它的主要焦点是定位不同的编译文件,并根据文件中的原始顺序匹配每个文件的函数。这种匹配方式依赖于开源函数的数量K,而不是二进制文件的大小N,因此可以实现显著的性能提升。

使用场景

我们认为Karta这个IDA插件有三大使用场景:

搜索目标文档,确定已使用的开源代码库列表(包含版本信息);

匹配支持的开源库及其中的符号,以帮助对恶意软件进行逆向工程分析;

匹配支持的开源库及其中的符号,以帮助在专用代码中搜索特定代码,实现针对二进制/固件的逆向工程分析;

项目目录结构

代码语言:javascript
复制
src:插件的源代码目录
configs:预置的*JSON配置文件
compilations:生成配置文件的编译提示,以及从过去的开源代码中获得的经验教训
docs:Sphinx文档目录

Karta识别器

Karta的识别器是一个较小的插件,用于标识二进制文件中现有(受支持的)开源库积起版本。因此,我们不再需要一次又一次地对同一个开源库进行逆向工程分析,我们只需要运行Karta识别器插件即可获得所用开源库的详细列表。Karta目前支持10多个开源库,其中包括:OpenSSL、Libpng、Libjpeg、NetSNMP、zlib等

Karta匹配器

识别目标代码所使用的开源代码库后,可以为特定库编译.JSON配置文件(例如libpng版本1.2.29)。编译后,Karta将自动尝试在加载的二进制文件中匹配开源代码库的函数或符号。除此之外,如果你的开源项目使用了外部函数(memcpy、fread或zlib_inflate),Karta也会尝试匹配这些外部函数。

工具安装

(Python 3 & IDA >= 7.4)

如需安装最新版本的Karta,我们需要本地环境配置好Python 3,然后使用下列命令将该项目源码克隆至本地:

代码语言:javascript
复制
git clone https://github.com/CheckPointSW/Karta.git

接下来,运行下列命令来运行Karta的安装脚本:

代码语言:javascript
复制
setup.py install

(Python 2 & IDA < 7.4)

在IDA 7.4发布时,Karta仅针对IDA 7.4或更新版本以及Python 3开发。Python2和更早的IDA版本仍然支持Karta v1.2.0版本,这很可能是Python2.X生命周期结束后最后一个受支持的版本。

项目地址

https://github.com/CheckPointSW/Karta

参考资料

https://karta.readthedocs.io/

https://research.checkpoint.com/karta-matching-open-sources-in-binaries/

https://research.checkpoint.com/thumbs-up-using-machine-learning-to-improve-idas-analysis

https://twitter.com/EyalItkin

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-11-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 FreeBuf 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 关于Karta
  • 使用场景
  • 项目目录结构
  • Karta识别器
  • Karta匹配器
  • 工具安装
    • (Python 3 & IDA >= 7.4)
      • (Python 2 & IDA < 7.4)
      • 项目地址
      • 参考资料
      • https://karta.readthedocs.io/
      • https://research.checkpoint.com/karta-matching-open-sources-in-binaries/
      • https://research.checkpoint.com/thumbs-up-using-machine-learning-to-improve-idas-analysis
      • https://twitter.com/EyalItkin
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档