攻防世界 逆向 game

game

工具

exeinfo pe,ida

过程

  1. 运行程序

    在这里插入图片描述

    程序的意思是要图案全部变亮。

  2. pe

    在这里插入图片描述

    32位,VC++

  3. ida

    在这里插入图片描述

    拖入ida发现,左侧显示的都是函数的地址,不是函数名。

    所以用shift+f12,查看字符串列表。

    在这里插入图片描述

    发现个关键字符串,双击跟进。

    在这里插入图片描述

    ctrl+x 获取代码地址,跟进。

    在这里插入图片描述

    f5 查看伪代码

    在这里插入图片描述

    在这里插入图片描述

    从最后的for循环中发现,函数进行了两次的xor运算。根据这个函数来写脚本。

    可以看到是v3和v60两个数组的运算,将上面的字符串分成两个数组,分别从v3和v60开始。

脚本

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,0]
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,0]
flag = ''
for i in range(57): a[i] ^= b[i] a[i] ^= 0x13 flag += chr(a[i]) i += 1
print(flag)

得到flag = zsctf{T9is_tOpic_1s_v5ry_int7resting_b6t_others_are_n0t}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值