WP-南邮CTF逆向第四题 WxyVM1

WP-南邮CTF逆向第四题 WxyVM1

用记事本打开后发现前面有elf,所以确认这个是一个elf文件.

  1. 打开IDA,载入WxyVM1,找到main函数,按F5,得到伪代码,并对伪代码进行分析
    在这里插入图片描述
  2. 对sub_400586这个函数进行分析
    在这里插入图片描述
  3. 观察这个函数,发现里面只有6010C0这个地址和604B80这个地址,并没有601060这个地址,说明这个函数是根据6010C0处的数据对用户输入的字符串进行重写,然后重写后的数据再与601060处的数据进行比较,下面对这个函数进行详细的分析,来观察它到底是怎么对用户输入的数据进行重写的
    在这里插入图片描述
  4. 下面我们再来观察一下6010C0处的数据
    在这里插入图片描述
    我们发现,这个数据非常有规律,再配合前面的for循环是i += 3,判断处6010C0处存放的其实是一个以3个字节为一个元素的数组,并且元素中的第一项(V0)决定了进行什么样的操作,第二项byte_6010C0[i + 1]决定了在哪个地方进行操作,第三项(V3)决定了与什么样的数进行操作
  5. 由于加减乘除,按位异或的逆向运算比较简单,我们发现这个题可以直接进行逆向,于是编写IDC脚本
    在这里插入图片描述
  6. 最终的到真正的flag 为nctf{Embr4ce_Vm_j0in_R3}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值