信息发布→ 登录 注册 退出

安卓逆向腾讯动漫app返回数据加密分析案例分享

发布时间:2026-01-11

点击量:
目录
  • 前言
  • 一、问题
    • 1.1抓包返回加密数据
    • 1.2查壳
  • 二、分析
    • 1.1 jadx-gui
    • 1.2 全局搜索加密函数
    • 1.3 疑似方法分析
  • 三、Frida
    • 1.1 反编译代码分析
    • 1.2 hook看下结果:
    • 1.3算法还原
    • 1.4 Python还原
  • 总结

    前言

    腾讯动漫app v8.1.6 工具:jadx、frida、pixel3 安卓10

    提示:以下是本篇文章正文内容,案例可供参考

    一、问题

    1.1抓包返回加密数据

    1.2查壳

    未发现加壳 直接打开jadx分析

    二、分析

    1.1 jadx-gui

    打开jadx-gui把apk文件拖进去等待片刻, 首先先找到包名package=“com.qq.ac.android” 为hook做准备。

    1.2 全局搜索加密函数

    在分析加密方法的时候凭借经验找出最可能是的地方,根据这个案例大概能看出来是AES加密的数据,搜索关键词encrypt 。

    结果如上, 看搜索出来的包名类com.qq.ac.android.library.util.CryptUtils比较像,点进去看下。

    1.3 疑似方法分析

    decodeHttpRequest()
    encodeHttpRespone()
    先不管了上frida hook看看

    三、Frida

    1.1 反编译代码分析

    代码如下:

        public String decodeHttpRequest(byte[] bArr, int i) {
            return ees3DecodeECB2Str(encryptKey(), bArr);
        }
        public String encodeHttpRespone(byte[] bArr, int i) {
            return ees3EncodeECB2Str(encryptKey(), bArr);
        }
    

    ees3DecodeECB2Str()方法传入了两个参数, 参数1:encryptKey(),bArr.

    1.2 hook看下结果:

    encryptKey() ⇒ 就是秘钥啦 bytes就是对应加密的响应数据。

    1.3算法还原

        public static byte[] des3EncodeECB(byte[] bArr, byte[] bArr2) {
            SecretKey generateSecret = SecretKeyFactory.getInstance("desede").generateSecret(new DESedeKeySpec(bArr));
            Cipher instance = Cipher.getInstance("desede/ECB/PKCS5Padding");
            instance.init(1, generateSecret);
            return instance.doFinal(bArr2);
        }
        public static String ees3EncodeECB2Str(byte[] bArr, byte[] bArr2) {
            byte[] bArr3 = new byte[0];
            try {
                return Base64.encodeToString(des3EncodeECB(bArr, bArr2), 2);
            } catch (Exception unused) {
                return "";
            }
        }
        public static byte[] ees3DecodeECB(byte[] bArr, byte[] bArr2) {
            SecretKey generateSecret = SecretKeyFactory.getInstance("desede").generateSecret(new DESedeKeySpec(bArr));
            Cipher instance = Cipher.getInstance("desede/ECB/PKCS5Padding");
            instance.init(2, generateSecret);
            return instance.doFinal(bArr2);
        }
    

    3DES(或称为Triple DES)是三重数据加密算法(TDEA,Triple Data Encryption Algorithm)块密码的通称。它相当于是对每个数据块应用三次DES加密算法。

    能看出来是3DES对称加密 没有魔改的地方。

    1.4 Python还原

    总结

    内容敏感关键部分就不发了,小伙伴跟着做一遍问题不大。

    以上就是腾讯动漫app返回数据加密分析的详细内容,更多关于返回数据加密分析腾讯动漫的资料请关注其它相关文章!

    在线客服
    服务热线

    服务热线

    4008888355

    微信咨询
    二维码
    返回顶部
    ×二维码

    截屏,微信识别二维码

    打开微信

    微信号已复制,请打开微信添加咨询详情!