bugku-reverse题目-游戏过关

下载附件,打开让我们玩个小游戏,通关就能拿到flag。

游戏不会玩,谈判失败,开始攻坚。使用 exeinfo 查看文件信息,发现是32位的。

因此,我们选择使用32位版本的 ida 对文件开始分析

先使用 shift + f12 打开strings窗口, ctrl + f 查看一下关键字符串 "flag"。发现有完成游戏时,给出提示语"done!!! the flag is "

双击进去看看,发现它被引用了,那就接着去看看是谁引用了它。继续双击箭头所指的函数

这里已经进入了引用"done!!! the flag is "的函数

按 F5 将汇编语言转换为伪c代码,这里就能看到 flag 的构成逻辑。

flag 整体的解密逻辑核心为:将两组长度均为 56 的数组按对应位置逐元素进行异或运算,运算结果再与十六进制常量 0x13(十进制 19)做异或运算,最终将每一位运算结果转换为对应的 ASCII 字符,拼接后即可得到由 56 个 ASCII 字符组成的完整 flag。

直接照着样子写个python脚本,flag就能出来

python 复制代码
a = [18, 64, 98, 5, 2, 4, 6, 3, 6, 48, 49, 65, 32, 12, 48, 65, 31, 78, 62, 32, 49, 32, 1, 57, 96, 3, 21, 9, 4, 62, 3, 5, 4, 1, 2, 3, 44, 65, 78, 32, 16, 97, 54, 16, 44, 52, 32, 64, 89, 45, 32, 65, 15, 34, 18, 16]
b = [123, 32, 18, 98, 119, 108, 65, 41, 124, 80, 125, 38, 124, 111, 74, 49, 83, 108, 94, 108, 84, 6, 96, 83, 44, 121, 104, 110, 32, 95, 117, 101, 99, 123, 127, 119, 96, 48, 107, 71, 92, 29, 81, 107, 90, 85, 64, 12, 43, 76, 86, 13, 114, 1, 117, 126]

flag = ""
for i in range(56):
    c = a[i] ^ b[i]
    c = c ^ 0x13
    flag = flag + chr(c)

print(flag)

zsctf{T9is_tOpic_1s_v5ry_int7resting_b6t_others_are_n0t}

相关推荐
云边散步10 小时前
godot2D游戏教程系列二(21)
笔记·学习·游戏·游戏开发
2301_7644413310 小时前
使用Python 和 Streamlit 构建的多维度游戏玩家数据分析
python·游戏·数据分析
一只鼠标猴10 小时前
甲方安全基线:配置规范与自动化核查落地指南
网络安全·安全架构·安全基线·基线检查
半路_出家ren11 小时前
Nginx基础学习
运维·网络·网络协议·学习·nginx·网络安全
渔民小镇11 小时前
告别 if-else 地狱 —— JSR380 参数验证在 ionet 中的应用
java·服务器·分布式·游戏
想你依然心痛12 小时前
HarmonyOS 5.0游戏开发实战:基于ArkGraphics 3D的轻量级物理引擎游戏
游戏·3d·harmonyos
缘友一世13 小时前
GOAD(game of Activate Directory)本地(ubuntu24.04+virtual box)部署
网络安全·域渗透
麦聪聊数据1 天前
跨云与多区服游戏架构下的数据库运维:基于webSQL的访问实践
数据库·sql·低代码·游戏·restful
智塑未来1 天前
《死亡搁浅2》沉浸式送快递指南:华硕天选6 Pro与ROG魔霸新锐,5款游戏本推荐
游戏·电脑
ambition202421 天前
从“分组游戏”到数学结构:等价关系、等价类、商集与划分完全指南
人工智能·游戏