CTF的示例WhyShouldIPay

先反编译apk

在这里插入图片描述
在这里插入图片描述

其中apk上边button按钮绑定的方法是verifyClick,下边button绑定的方法是showPremium,所以就要hook这两个方法,通过观察发现verifyClick需要请求网页最终是会失败,所以只能通过hook showPremium方法来实现目的,查看showPremium方法,调用了getMac,getKey这两个方法,然后再分别观察getMac,getKey方法,其中getMac是获取本机的信息,而getKey是获取app中的key,但key是通过以下生成的

在这里插入图片描述

所以还需要hook MainActivity类中的xor方法,xor方法如图所示:

在这里插入图片描述

最后的hook代码

	var launcherActivity = Java.use("de.fraunhofer.sit.premiumapp.LauncherActivity");
    var mainActivity = Java.use('de.fraunhofer.sit.premiumapp.MainActivity');

    launcherActivity.getKey.implementation = function(){
        var act = mainActivity.$new();
        var result = act.xor(stringToBytes("14:4F:8A:F6:E2:F8"),stringToBytes("LICENSEKEYOK"));

        var key = bin2String(result);
        console.log(key);
        return key;
    };

    launcherActivity.verifyClick.implementation = function (v) {
		this.showPremium(v);
    };

hook前效果

在这里插入图片描述

Hook后效果:

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值