前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >大众点评app分析记录

大众点评app分析记录

作者头像
李玺
发布2022-03-24 09:52:02
1.4K0
发布2022-03-24 09:52:02
举报
文章被收录于专栏:爬虫逆向案例

本文是大众点评APP的分析记录。

声明:文章内容仅供参考学习,如有侵权请联系作者进行删除。

案例环境:夜神安卓5,APP版本10.45.7。 工具:Frida、Charles。

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

点评看不到http/https数据包,它走了自己的CIP协议,网上的抓包方案有降级或者V**转发。

本文通过hook的方式来抓http/https数据包。

用super-Jadx时内存溢出,我删除了一些无用文件,将dex分批反编译,这块就不再说了。

文章目录

Hook 抓包

Hook代码:

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

执行hook脚本后,成功抓到包。

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

Hook http/https请求信息

Hook代码:

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

查看执行结果:

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

Hook 数据解密

Hook自定义的对象时,可以使用r0gson.dex的gson进行输出。 r0gson.dex下载链接: https://pan.baidu.com/s/1V59p4NKhrXSa_xpdM_LmtA?pwd=53nm 将其放到设备的 /data/local/tmp 目录中

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

查看执行结果。

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

Hook 明文响应内容

Hook代码:

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

查看执行结果:

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

格式化后和设备页面信息对比,发现内容一致。

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

Hook 代码整理

代码语言:javascript
复制
import frida, sys
def on_message(message, data):
    print("[%s] => %s" % (message, data))

session = frida.get_usb_device().attach('com.dianping.v1')

js_code = """
Java.perform(function(){
    
    Java.openClassFile("/data/local/tmp/r0gson.dex").load();
    const gson = Java.use('com.r0ysue.gson.Gson');
    
    var c1 = Java.use("com.dianping.nvnetwork.tunnel2.a");
        c1.isSocketConnected.implementation = function () {
        return false;
    }
    
    
    var bb = Java.use("com.dianping.dataservice.mapi.b");
    bb.b.overload('java.lang.String', 'com.dianping.dataservice.mapi.c').implementation = function(a1, a2){
        //console.log("**************************** http start");
        console.log(a1);
        // console.log('a2:', a2);
        var res = this.b(a1, a2);
        // console.log(res);
        //console.log("**************************** http end");
        return res;
    }
    
    var d = Java.use("com.dianping.dataservice.mapi.impl.d")
    d.a.overload('java.lang.String', 'java.lang.String').implementation = function(a1, a2){
        //console.log("**************************** https start");
        var res = this.a(a1, a2);
        console.log(res);
        //console.log("**************************** https end");
        return res;
    };
    
    
    var c3 = Java.use("com.dianping.picassocontroller.jse.c");
	c3.a.overload('com.dianping.picassocontroller.vc.e', 'java.lang.String', '[Ljava.lang.Object;').implementation = function (a,b,c) {
		console.log('a: ', a);
		console.log('b: ', b);
		console.log('c: ', c);
		var v = this.a(a,b,c)
		console.log(v.string())
	    return v;
	}
	
     hook decryptData
    var ByteString = Java.use("com.android.okhttp.okio.ByteString");
    var SocketSecureManager = Java.use("com.dianping.nvnetwork.tunnel.Encrypt.SocketSecureManager");
    SocketSecureManager.decryptData.implementation = function(bstr, str){
       console.log('bstr: ', bstr);
       console.log('bstr-tojson:',gson.$new().toJson(bstr));
       console.log('bstr-hex: ', ByteString.of(bstr).hex());
       console.log('str: ', str);
       var ret = this.decryptData(bstr, str);
       // console.log(Java.use("android.util.Log").getStackTraceString(Java.use("java.lang.Throwable").$new()));
       console.log('decryptData Results: ', ByteString.of(ret).hex());
       return ret;
    }
    
    
    // var AESUtils = Java.use("com.meituan.android.common.unionid.oneid.util.AESUtils");
    // AESUtils.decrypt.implementation = function(str){
    //     console.log('decrypt is called');
    //     str = "RNtYlL8BsMe4EOqz-X0a1WAw3FwHsr1fdXSOBRnPEF_MiYYvJ1GSqvIIA1NwwTUxuoNWGGueSBRl50pmkidrgdQmVUUScNhW4FpBl1ZFPSyJAz4Zo0PpDNStJnb5JCf8fEe8oDXOCAsptjpuGpRJGClsKeIqe9ph6gAyvYfOk2XafwXbHf4VlsjATDVI7r4f-2s6QQ5Mfc6jvRMyqNdLJNtLwg5XDEmL4Leu7fCnHJbJ46O8hy8MFuN38avBqh6N-2s6QQ5Mfc6jvRMyqNdLJLVj6r8HF-qtkeIznxOc2qXKVyQ4dzMLEBQjCADd9vGF"
    //     var ret = this.decrypt(str);
    //     console.log('decrypt ret value is ' + ret);
    //     return ret;
    // };
  
})
"""

script = session.create_script(js_code)
script.on('message', on_message)
script.load()
sys.stdin.read()

备注

数据是通过AES算法进行的加解密,找到key和iv就能复写了。

作者只是简单分析并记录了下。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022/03/22 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 文章目录
  • Hook 抓包
  • Hook http/https请求信息
  • Hook 数据解密
  • Hook 明文响应内容
  • Hook 代码整理
  • 备注
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档