BABYRE 【攻防世界】 Reverse
题目
丢进Exeinfo PE里面,得到64bit,无壳
丢进IDA pro(x64)里面,找到主函数
代码中有一个花指令:*(unsigned int (__fastcall **)(char *))judge)(input)
unsigned int (__fastcall **)(char *)
:这是一个函数指针类型,指向一个接受char *
类型参数并返回unsigned int
类型的函数。__fastcall
是一种调用约定,它指定了函数参数传递的方式。(*)
:这表示函数指针的间接引用,即对函数指针judge
进行解引用,获取其指向的函数。(char *)judge
:这是对函数指针judge
的解引用,将其当作一个函数调用,并传递input
作为参数。- 因此,
(*(unsigned int (__fastcall **)(char *))judge)(input)
的整体含义是:调用judge
指向的函数,传递input
作为参数,并期望该函数返回一个unsigned int
类型的值
双击judge追踪看看,有的大佬说会双击跟踪不了报错,我的可以双击跟踪
一开始我还没发现有问题,以下内容参考大佬wp
选中public judge,按C,跳出“Directly convert to code?”-->Yes,变成了汇编
把红色区域全部框选起来,按P,试图重新生成function——这里会出现一个红色错误endp ; sp-analysis failed
打开IDA的Options--->General-->Disassembly,勾选“Stack pointer”,打开堆栈指针
发现出现负值,说明我的IDA7.7存在指针错误
我看几个大佬的wp,他们都没有去解决这个指针问题,可能是不影响解题吧,所以我也没去管它
这里放上解决错误的资料:IDA出现"sp-analysis failed"和F5(反编译)失败-CSDN博客
视线回到主函数,在第8行,judge是一个数组,但是在第12行,judge是一个函数指针
从二进制机器码的角度看,可以理解成这个judge函数的每个字节都被异或了
用人话说,这个函数被加密了
解决方式也是参考大佬的wp——使用IDApython脚本解决:file-->script command
大佬的脚本如下:
1 add=0x600b00
2 for i in range(182):
3 PatchByte(add+i,Byte(add+i)^0xC)
但是,我运行会报错,我的IDA没有这个函数,导入了ida_bytes
模块也没有用
放下我这边能运行的代码(记得左下角Scripting language选python):
1 import idaapi
2
3 add = 0x600b00
4 for i in range(182):
5 idaapi.patch_byte(add + i, idaapi.get_byte(add + i) ^ 0xC)
- idaapi.patch_byte函数用于修改指定地址的字节,它接受两个参数:地址和要写入的字节值。
- idaapi.get_byte函数用于获取指定地址的字节值,它接受一个参数:地址,并返回该地址处的字节值
按一次就可以了,变成下面这样:
选中judge,按C(变成汇编),框选地址B00~BB5,也就是所有的红色区域,按P(重新生成function)
此时可以在左边找到judge函数内容
点进去,F5反汇编
这个代码不难理解,写逆向脚本也不难,但是我这里又犯了一个错
我以为只需要拿v2去异或解题,v3虽然也在代码中,但是后面都没再提及了,我以及单纯就是干扰,或者是没有用的乱码数据
我只用v2运行解题脚本的时候,结果就是一个:flag
我看到这个老开心了,证明我的代码是没有错误的,思路大方向也是没有错误了,但是之后就没有找到其他的东西了
看来看去,还是v3最可疑,单独用v3运行解密脚本,是一堆没有价值可读性的东西
后面看了大佬的脚本,要把v2与v3加在一起
啊?这是为什么??代码里没有体现啊????然后我就去找了资料
双击v2,点进去看看栈
双击v3,也是看看栈
20~1C:5个,刚好对的上v2的长度
1B~13:9个,也刚好对的上v3的长度
有没有发现,v2和v3用的是一块连续的空间啊啊啊
修改后的脚本如下:
1 s1 = "fmcd"
2 s2=chr(0x7F)
3 s3="k7d;V`;np"
4 key=s1+s2+s3
5 input_str = ""
6
7 for i in range(len(key)):
8 input_str += chr(ord(key[i]) ^ i)
9
10 print(input_str)
运行结果: flag{n1c3_j0b}
BABYRE 【攻防世界】 Reverse的更多相关文章
- 攻防世界 reverse 进阶 10 Reverse Box
攻防世界中此题信息未给全,题目来源为[TWCTF-2016:Reverse] Reverse Box 网上有很多wp是使用gdb脚本,这里找到一个本地还原关键算法,然后再爆破的 https://www ...
- 攻防世界 reverse evil
这是2017 ddctf的一道逆向题, 挑战:<恶意软件分析> 赛题背景: 员工小A收到了一封邮件,带一个文档附件,小A随手打开了附件.随后IT部门发现小A的电脑发出了异常网络访问请求,进 ...
- 攻防世界 reverse tt3441810
tt3441810 tinyctf-2014 附件给了一堆数据,将十六进制数据部分提取出来, flag应该隐藏在里面,(这算啥子re,) 保留可显示字符,然后去除填充字符(找规律 0.0) 处理脚本: ...
- 攻防世界 reverse 进阶 APK-逆向2
APK-逆向2 Hack-you-2014 (看名以为是安卓逆向呢0.0,搞错了吧) 程序是.net写的,直接祭出神器dnSpy 1 using System; 2 using System.Diag ...
- 攻防世界 reverse BABYRE
BABYRE XCTF 4th-WHCTF-2017 int __cdecl main(int argc, const char **argv, const char **envp) { char ...
- 攻防世界 reverse Windows_Reverse2
Windows_Reverse2 2019_DDCTF 查壳: 寻找oep-->dump-->iat修复 便可成功脱壳 int __cdecl main(int argc, con ...
- 攻防世界 reverse BabyXor
BabyXor 2019_UNCTF 查壳 脱壳 dump 脱壳后 IDA静态分析 int main_0() { void *v0; // eax int v1; // ST5C_4 char ...
- 攻防世界 reverse parallel-comparator-200
parallel-comparator-200 school-ctf-winter-2015 https://github.com/ctfs/write-ups-2015/tree/master/sc ...
- 攻防世界 reverse 进阶 8-The_Maya_Society Hack.lu-2017
8.The_Maya_Society Hack.lu-2017 在linux下将时间调整为2012-12-21,运行即可得到flag. 下面进行分析 1 signed __int64 __fastca ...
- 攻防世界 reverse easy_Maze
easy_Maze 从题目可得知是简单的迷宫问题 int __cdecl main(int argc, const char **argv, const char **envp) { __int64 ...
随机推荐
- angularjs国际化多语言,angular-translate教程详解,$translate.instant()为什么不生效
壹 ❀ 引 最近项目要求支持国际化多语言,由于项目用的还是angularjs,那么首当其冲的选择了angularjs封装的I18N插件angular-translate,本文主要会从三个方向展开讨论, ...
- NC16655 [NOIP2005]过河
题目链接 题目 题目描述 在河上有一座独木桥,一只青蛙想沿着独木桥从河的一侧跳到另一侧.在桥上有一些石子,青蛙很讨厌踩在这些石子上.由于桥的长度和青蛙一次跳过的距离都是正整数,我们可以把独木桥上青蛙可 ...
- [技术选型与调研] 流程引擎(工作流引擎|BPM引擎):Activiti、Flowable、Camunda
1 概述:流程与流程引擎 低代码平台.办公自动化(OA).BPM平台.工作流系统均需要[流程引擎]功能 BPM平台与工作流系统的区别,参见本文档:3.2 章节 流程引擎是任务分配软件(例如业务流程管理 ...
- Oracle开发人员守则
以下为Oracle大师级语录: Oracle Database developers should follow is to do everything they can in SQL. What t ...
- Go语言并发编程(2):channel 通道介绍和使用
一.简介 channel 不仅可以用于 goroutine 间进行安全通信,还可以用于同步内存访问. 而且 Go 社区强烈推荐使用 channel 通道实现 goroutine 之间的通信, 不要通过 ...
- Sourcetree 如何关联自己的gitlab仓库
现在有些企业自己搭建了gitlab服务器,通过sourcetree从企业服务器拉取代码的时候会提示认证失败.今天搞了大半天才搞懂,给我自己做个笔记. 添加账户 托管服务商 选择 GitLab CE 托 ...
- Entity Framework发布到IIS报错
参考资料:https://www.cnblogs.com/mrma/p/5404584.html 报错信息 The Entity Framework provider type 'System.Dat ...
- 第128篇:浏览器存储(cookie、webStorage、 IndexedDB)
好家伙,本篇为<JS高级程序设计>第二五章"浏览器存储"学习笔记 我们先来讲个故事 一个"薅羊毛"的故事 (qq.com) 概括一下,就是 有个人通 ...
- DataGear 制作自定义柱状图条目颜色的数据可视化看板
DataGear 看板提供了dg-chart-options图表选项配置功能,可自定义样式.位置.显示内容等图表选项,其中的processUpdateOptions回调函数配置项,可以在图表更新数据前 ...
- SpringCloud 网关组件Gateway
官网文档: https://docs.spring.io/spring-cloud-gateway/docs/2.2.5.RELEASE/reference/html/ 1. 概述 1.1 什么是网关 ...