CTF Reverse fantasy.apk解题思路

CTF Reverse fantasy.apk解题思路

一、文件分析

  1. 文件和解题脚本看这里
  2. 动态运行界面提示输入信息进行check
    在这里插入图片描述
  3. chec按钮点击后出出现一个Toast,提示无效!在这里插入图片描述
  4. 由此可以判断这个apk文件应该是个flag checker。

二、解题思路

  1. jeb中打卡该apk查看源码,,,还好,程序只有一个MainActivity,从button_click函数中可知flag总长度为38位,去掉flag{},还剩32位。然后调用了check()。
    在这里插入图片描述
  2. 我的屏幕就这么大,装不下后面的数据显示啦~~~
  3. check()很简单,传入输入的editText()内容,经过四层for循环,然后有个if语句进行判断,判断成功则return 1.
    在这里插入图片描述
  4. 这里给出了两个数组,分别是v1和ahhhh,其中v1.shape=(32, 32),ahhhh.shape=(1,32)
  5. 我们来看四层for循环,,前面两层没啥好讲的,0x20=32,就是遍历32行32列的数组,然后在第三层for中,so<v1[i][j],我们可以认为so遍历了v1[i][j]次,
  6. 第四层for循环中,由于awesome<its,所以该层是遍历了its次,,而its是我们输入的字符转成了整型数字。
  7. 这就好理解啦,,第3,4层for循环使得
    t h a t s = v 1 [ i ] [ j ] ∗ i t s [ j ] thats = v1[i][j] * its[j] thats=v1[i][j]its[j]
  8. 然额,在第二层循环中,遍历了32次,得到
    t h a t s = ∑ j = 0 32 v 1 [ i ] [ j ] ∗
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值