闲鱼抓包后,获取接口加密参数

前期准备

  雷电模拟器

  pycharm

 frida

反编译

我们可以看到,在每次请求前,都会调用InnerSignImpl.getUnifiedSign方法。

我们可以hook一下这个类,看一下每次的请求和返回值。

frida hook

// hook mtopsdk.mtop.global.SwitchConfig,返回false,禁用spdy协议,可以进行抓包
Java.perform(function() {
    var SwitchConfig = Java.use('mtopsdk.mtop.global.SwitchConfig');
    SwitchConfig.isGlobalSpdySwitchOpen.overload().implementation = function () {
        return false;
    }
    
    var InnerSignImpl = Java.use("mtopsdk.security.InnerSignImpl");
    InnerSignImpl["getUnifiedSign"].implementation = function (params, ext, appKey, authCode, useWua, requestId) {
       console.log('\ngetUnifiedSign is called' + ', ' + '\nparams: \n' + params + '\n' + 'ext: \n' + ext + '\n' + 'appKey: \n' + appKey + '\n' + 'authCode: \n' + authCode + '\n' + 'useWua: \n' + useWua + '\n' + 'requestId: \n' + requestId);
       var ret = this.getUnifiedSign(params, ext, appKey, authCode, useWua, requestId);
        console.log('getUnifiedSign ret value is ' + ret);
        return ret;
    };
});

返回值如下

{x-sgext=JBJY和谐GadJq1GDdaMZrxiKkCqp71XvFeMVrxXjFYQ==,

x-umt=ppqBk和谐HXL,

x-mini-wua=aOAQkrIq和谐h/t8wx/Pzdd03NfyaIDYjqWx0zzfXaqrzCW7ziKW/xVrQX38UPs2IQ=, x-sign=azU7Bc002和谐dWbQ8lmjwJjImMyYyJjMm}

可以看到,这个接口的返回值,就是加密信息。

我们可以通过生成请求参数,通过这个方法,生成加密串,达到接口请求的目的。

搜索接口

试验了一下搜索接口

搜索结果已经经过解析。原来接口返回的……太乱了。

结论

这个方案需要一直开启模拟器,略有麻烦,接口请求次数过多,还会导致出现滑块。

继续深入研究unidbg方式去生成加密串。

  • 6
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值