软件编程
位置:首页>> 软件编程>> Android编程>> 安卓逆向腾讯动漫app返回数据加密分析案例分享

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

作者:别None了  发布时间:2023-10-24 10:36:46 

标签:安卓逆向,数据分析,腾讯动漫

前言

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

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

一、问题

1.1抓包返回加密数据

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

1.2查壳

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

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

二、分析

1.1 jadx-gui

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

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

1.2 全局搜索加密函数

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

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

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

1.3 疑似方法分析

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

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

三、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);
   }

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

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

1.2 hook看下结果:

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

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返回数据加密分析案例分享

来源:https://blog.csdn.net/Leetengteng/article/details/122602954

0
投稿

猜你喜欢

手机版 软件编程 asp之家 www.aspxhome.com