老司机带你玩转Radare2

Radare2实战(图片来源:hetianlab.com)

说起逆向,你想到的可能是IDA Pro,OllyDBG。

而Radare2是一款开放源代码的逆向工程平台,它的强大超越你的想象,包括反汇编、分析数据、打补丁、比较数据、搜索、替换、虚拟化等等,同时具备超强的脚本加载能力,并且可以运行在几乎所有主流的平台(GNU/Linux, .Windows *BSD, iOS, OSX, Solaris…)上。可谓是一大神器。

这里我们使用Kali系统来学习它,因为Kali系统自带了这个神器。

打开终端,使用radare2 -h 可以查看其帮助信息

radare2帮助(图片来源:hetianlab.com)

radare2里面有个很牛逼的工具:rabin2

 rabin2 可以获取包括ELF, PE, Mach-O, Java CLASS文件的区段、头信息、导入导出表、字符串相关、入口点等等,并且支持几种格式的输出文件。使用man rabin2 可以查看rabin2的使用帮助文档。

然后我们通过破解一个crackme来学习神器radare2的使用。

首先使用 rabin2 打印出二进制文件的系统属性、语言、字节序、框架、以及使用了哪些加固技术

rabin2 -I (图片来源:hetianlab.com)

  可以看到这是一个32位的 elf 文件,没有剥离符号表并且是动态链接的

  接下来尝试运行它

运行 (图片来源:hetianlab.com)

  可以看到,不论是否加参数都会显示wrong。

  接下来使用radare2来进行破解

(图片来源:hetianlab.com) 

  可以黄色输出了一个地址 (0x08048370),这就是它自动识别的程序入口点

  或者也可以使用ie命令手动打印出入口点

(图片来源:hetianlab.com)

  接下来输入aa或者aaa进行细致的分析

  分析完成之后, r2会将所有有用的信息和特定的名字绑定在一起,比如区段、函数、符号、字符串,这些都被称作 'flags', flags 被整合进 ,一个 flag 是所有类似特征的集合

  接下来看看所有的flag

  我们打印出imports下面的信息

(图片来源:hetianlab.com)

  为了获取更多的信息,我们可以再列出数据段里的字符串

(图片来源:hetianlab.com)

  出现了关键字,一个是success,一个是我们之前运行时的wrong….

  那我们接下来就跟着success走,看看哪儿进行了调用

  输入命令axt @@ str.*

(图片来源:hetianlab.com)

  'axt' 命令用来在 data/code段里找寻某个地址相关的引用(更多的操作,请看 'ax?').

  '@@'就像一个迭代器,用来在地址空间里不断地匹配后面一系列相关的命令(更多操作,请看 '@@?')

  'str.*' 是一个通配符,用来标记所有以 'str.'开头的信息,不光会列出字符串标志,同时也包括函数名,找到它们到底在哪里以及何处被调用。

  接下来我们看看radare2分析出来哪些函数

(图片来源:hetianlab.com)

  看到两个引起我们注意的sym.beet和sym.rot13

  接下来我们用 's main'  指令定位到main函数入口处,然后用 'pdf'输出反汇编代码

(图片来源:hetianlab.com)

  分析函数的执行流程,我们知道二进制程序是通过获取 beet函数的返回结果来判断是否正确

  因此我们去beet函数反汇编的部分看看

  因此我们定位到beet

  输入pdf@sym.beet进行跳转

(图片来源:hetianlab.com)

  自动跳转到beet函数的反汇编部分

(图片来源:hetianlab.com)

 我们看到输入的参数被拷贝到了一个缓存空间里,这个空间的地址是 ‘ebp – local_88h’ 。 'local_88h' 就是十进制的 136。由于4个字节会被用来保存 ebp 的地址,4个字节被用来保存返回地址,所以这个缓冲区得大小是 128个字节.它们加起来刚好是 136. 我们输入的参数被拷贝到缓冲区后被用来和 sym.rot13的返回结果作对比, Rot-13 是一个著名的替换密码算法,在ctf和crackme中被广泛使用,这个函数接受了9个十六进制值作为参数,但是上图中看起来r2好像没有识别出来到底是什么字符,这里我们需要用 'ahi s' 来做些处理.输入


(图片来源:hetianlab.com)

 ahi s 是用来设置字符串特定的偏移地址(使用 ahi? 获取更多用法),@@是一个迭代器,可以用来接受后面输入的多个参数,执行完这条命令后,图形视图会自动刷新。

(图片来源:hetianlab.com)

  可以看到

  0x080485a3

  0x080485ad

  0x080485b7

  后面的字符都已经显示出来了

  我们已经看到了之前无法识别的字符串'Megabeets'(根据字节序反向压栈顺序得到).

  这个二进制文件将我们传入的参数来和经过 rot13 处理后的 'Megabeets' 作比较

  接下来我们通过rahash2求出这个字符串的校验值

(图片来源:hetianlab.com)

至此,程序的逻辑就很清楚了: 'Zrtnorrgf' 就是用来和我们输入的字符串作比较,成功则返回success。我们验证一下:接下来输入ood?进入调试模式 将Zrtnorrgf作为参数进行调试,输入dc查看结果

(图片来源:hetianlab.com) 

  输出了success,我们成功破解了这个小软件,也借此掌握了radare2的基本用法。

是不是跃跃欲试了呢?实践才能学到真本领!戳下面的链接即可进行在线实操,无需自己搭建环境噢!

                    👇

戳它>>Radare2实战<<戳它

(本文来源:合天网安实验室--一家实操型在线网络安全学习平台) 

本文由合天网安实验室原创,转载请注明来源。

关于合天网安实验室

合天网安实验室(www.hetianlab.com)-国内领先的实操型网络安全在线教育平台

真实环境,在线实操学网络安全 ;

实验内容涵盖:系统安全,软件安全,网络安全,Web安全,移动安全,CTF,取证分析,渗透测试,网安意识教育等。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,230评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,261评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,089评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,542评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,542评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,544评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,922评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,578评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,816评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,576评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,658评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,359评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,937评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,920评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,859评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,381评论 2 342

推荐阅读更多精彩内容

  • 第2章 基本语法 2.1 概述 基本句法和变量 语句 JavaScript程序的执行单位为行(line),也就是一...
    悟名先生阅读 4,114评论 0 13
  • 一、温故而知新 1. 内存不够怎么办 内存简单分配策略的问题地址空间不隔离内存使用效率低程序运行的地址不确定 关于...
    SeanCST阅读 7,774评论 0 27
  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 3,204评论 0 4
  • 所谓自由,不是随心所欲,而是自我主宰。
    梓垚兮阅读 150评论 0 0
  • 在我的印象中,这绝对是一个老生常谈的问题。若是在情窦还未开的以前,我一定觉得,有啊,当然有,我有好多男的小伙伴呢...
    玖歌不是哥阅读 570评论 0 2