game题目的笔记

先把文件下载下来,发现是exe文件,没有壳

拖入ida分析

 在字符串搜索里面找到flag

 推测

flag以后部分的数据均为答案

 不难看出,以上数据通过两次异或运算得到结果

i循环56次

将v3下一字节进行*v60下一字节的异或

将v3下一字节进行0x13u的异或(undesign的十六进制)

根据分析进行反编译

xor=[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]
key=[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(56):
    a = key[i]
    a ^= 0x13
    a ^= xor[i]
    flag += chr(a)

print(flag)

代码借鉴ZSCTF game · 大专栏 (dazhuanlan.com)

(只能打出list和循环异或的我)

然后得出flag

这个函数理解起来并不算难

难的部分在于他并不是主调函数

在做的过程中花了部分时间对主调函数溯源,并理清函数关系和分支

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值