ApoorvCTF Rust语言逆向实战

上周参加了国外的比赛,名称叫:ApoorvCTF

看一下老外的比赛跟我们有什么不同,然后我根据国内比赛对比发现,他们考点还是很有意思的,反正都是逆向,哈哈哈

Rusty Vault

题目描述:

In the heart of an abandoned shrine, there's an old, rusted vault said

to guard an unspeakable secret. Many have tried to unlock it, but the

door's demands are strange and no key seems to fit.

进入main函数,开始分析

这个命名方式,大概率是Rust语言

对于rust语言逆向,一般采用动态调试分析的方法

主要还是看汇编,因为F5根本看不出来啥东西。。。

从if比较处,可以看到成功和失败两个结果

那么这个比较绝对很关键

进入后发现,啥也没啊?

坏了,得看汇编,为代码估计又出问题了

发现了check2,果然为代码啥也看不到

对比check1-2

发现是在检测输入的字符串的字符类型,还是冲突的,不管了继续分析

下面可以看到失败

往下滑动可以看到成功

什么意思?

我猜测这题是改条件,然后动态输出flag?还有这好事

后面都是正常输出flag了

那么我们现在去解密的地方回溯,估计我要改一些判断,改变流程,让程序正常走到解密的地方,然后输出flag

帮助网安学习,全套资料S信免费领取:

① 网安学习成长路径思维导图

② 60+网安经典常用工具包

③ 100+SRC分析报告

④ 150+网安攻防实战技术电子书

⑤ 最权威CISSP 认证考试指南+题库

⑥ 超1800页CTF实战技巧手册

⑦ 最新网安大厂面试题合集(含答案)

⑧ APP客户端安全检测指南(安卓+IOS)

教大家一个回溯方法

对标签疯狂X键,交叉引用定位回溯

最终定位到密文,发现是aes_128_cbc模式

需要:key+IV+密文=明文

这是一种思路,大家可以尝试

本文修改流程,让他自动输出明文

现在的思路就是:

x键回溯定位关键标签,修改关键判断

让程序自动走向解密

nop掉check1 和 check2

让他们走向自动解密的方向

最终运行程序得到flag,静态patch流程,绕过check1-chekc2

复制代码
apoorvctf{P4tch_1t_L1k3_1t's_HOt}

这在我们国内比赛还是很少见到的,国内大概率要写脚本解密,或许国内认为加密才是CTF的重点。国外侧重逆向本身,如果可以patch修改流程得到flag,为什么要去写解密脚本呢?

锻炼了我们通过汇编分析程序流程的能力,而不是为代码一键分析。

相关推荐
mottte5 天前
BUUCTF[极客大挑战 2019]Havefun 1题解
php·web·ctf
mottte5 天前
BUUCTF[ACTF2020 新生赛]Include 1题解
web·ctf·文件包含漏洞
Star abuse9 天前
2025一带一路暨金砖国家技能发展与技术创新大赛第三届企业信息系统安全赛项
安全·web安全·ctf·全国职业院校技能大赛
落寞的魚丶9 天前
第三届宁波技能大赛网络安全赛项样题
网络安全·渗透测试·ctf·服务器配置·第三届宁波技能大赛
kali-Myon11 天前
栈迁移与onegadget利用[GHCTF 2025]ret2libc2
c语言·安全·pwn·ctf·栈溢出·栈迁移·onegadget
亿.612 天前
“轩辕杯“云盾砺剑CTF挑战赛 Web wp
web·ctf·writeup
未完结的牵挂16 天前
第二届帕鲁杯 solar_Linux后门排查 WP
网络安全·ctf·应急响应
ALe要立志成为web糕手17 天前
php://filter的trick
安全·web安全·网络安全·php·ctf
uwvwko20 天前
ctfshow——web入门254~258
android·前端·web·ctf·反序列化
uwvwko21 天前
BUUCTF——web刷题第一页题解
android·前端·数据库·php·web·ctf