第36天:攻防世界-Mobile—Ph0en1x-100

工具

今天体验体验新工具。俗话说,工欲善其事必先利其器。

APKIDE3.3.0  也叫APK改之理

详细讲解

在APKIDE中打开apk文件,然后打开java源码,

定位关键代码:

都调用getSecret方法,那就是说参数相等即可。

即getFlag()=encrypt(paraView)         paraView就是我们的输入。

两个native方法,用IDA加载so文件分析。

encrypt方法:

对字符串的每个字符的ascii值减一。

getFlag方法:

比较乱,但是这个方法没有外部输入参数,就是如果我们能拿到这个方法的运行结果就OK了。

解题思路

经过以上分析,通过getFlag方法得到的字符串然后每个字符的ascii值+1,程序就可以运行成功。

关键就是getFlag方法的执行结果。

有两个思路:

1.动态调试。还不熟练(好吧,我根本不会!)

2.修改smali源码,让app显示getFlag方法的执行结果。

通过APKIDE修改smali源码,本来显示 Failed的地方,让其执行getFlag方法,将执行结果存入v1寄存器。

最后每个字符的ascii值+1,即可得到flag:

flag = "ek`fz@q2^x/t^fn0mF^6/^rb`qanqntfg^E`hq|"
result = ''
for i in flag:
    result += chr(ord(i) + 1)
print(result)

 

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值