首先配置模拟器,进行root,安装面具,常用工具等。
在模拟器硬盘切换成 可写系统盘
data:image/s3,"s3://crabby-images/c7cb6/c7cb65e617134674e86edf5bb249b1ce0010bbb9" alt="Untitled"
开启root权限
data:image/s3,"s3://crabby-images/52b36/52b3672f5da8955b0d20f062458587a9773d73a6" alt="Untitled"
开机后打开ADB调试
data:image/s3,"s3://crabby-images/ffbd1/ffbd107be69c7a11341d5349be845c0ac096ec0d" alt="Untitled"
打开后会启动一个终端 代表已经打开 之后关闭即可
data:image/s3,"s3://crabby-images/c836e/c836eec8a5763d10f80a200ffcc27b717e3baa6f" alt="Untitled"
使用adb命令可以查看到 当前设备
data:image/s3,"s3://crabby-images/3d6c1/3d6c1814596d86319c6c1515e1479efc4b2b07ba" alt="Untitled"
导出burp 和 yakit的证书到桌面
data:image/s3,"s3://crabby-images/66281/6628145befd3aacd9c9e226cee1bad53a923f087" alt="Untitled"
之后转换证书格式 并导入到模拟器的system证书文件夹下
#burpsuite
openssl x509 -inform DER -in burp.der -out burp.pem
hash=$(openssl x509 -inform PEM -subject_hash_old -in burp.pem | head -n 1)
# 将 pem 证书改成 hash + .0 的格式
new_hash="${hash}.0"
mv burp.pem "$new_hash"
# 将证书直接放到系统证书文件夹下
adb push "$new_hash" /system/etc/security/cacerts/
#yakit
hash=$(openssl x509 -inform PEM -subject_hash_old -in yakit.pem | head -n 1)
# 将 pem 证书改成 hash + .0 的格式
new_hash="${hash}.0"
mv yakit.pem "$new_hash"
# 将证书直接放到系统证书文件夹下
adb push "$new_hash" /system/etc/security/cacerts/
data:image/s3,"s3://crabby-images/4169e/4169e1bd2452a735729410e72170c6acf83fdad3" alt="Untitled"
使用burp进行抓包测试
data:image/s3,"s3://crabby-images/c693d/c693d9f13c7565164f10a6980842dc7c7c05e2a9" alt="Untitled"
burp能抓到https包
data:image/s3,"s3://crabby-images/15a68/15a680322fa4eb899163a574c2c16ddc10e7cf63" alt="Untitled"
接下来安装面具
HuskyDG/magisk-files (github.com)
data:image/s3,"s3://crabby-images/44ef8/44ef8457501b32e91b5f88c002555bdfe7dee170" alt="Untitled"
将apk拖到模拟器中进行安装
之后打开app进行安装
data:image/s3,"s3://crabby-images/c5b77/c5b77d53858512a773c29695612fa805e526a60d" alt="Untitled"
选择直接安装
data:image/s3,"s3://crabby-images/b3d99/b3d993a0a5d440fffaccc679dffbfdf9dd22d1df" alt="Untitled"
安装完成后进行重启
data:image/s3,"s3://crabby-images/40fef/40fefb902e3a21849735b935d772448e7d99fddf" alt="Untitled"
开机后再打开面具 会报错
data:image/s3,"s3://crabby-images/c8411/c8411c1dad7bb60c147186eb2a14d30ed6ca7f46" alt="Untitled"
重启后需要再次打开adb
使用 root 权限删除之前冲突的 su 相关文件
adb connect 127.0.0.1:16385
adb shell
su
data:image/s3,"s3://crabby-images/df4e6/df4e655798ab85958440557ac6fa27aa2702679e" alt="Untitled"
mv /system/xbin/su /system/xbin/su.bak
mv /system/app/SuperUser/ /system/app/SuperUser-Bak/
之后面具正常
data:image/s3,"s3://crabby-images/25c46/25c46f915512f0228f1d72393f4dbd2a6112286a" alt="Untitled"
frida测试
mac安装frida环境
pip3 install frida
pip3 install frida-tools
pip install Pyro4
下载frida-server-16.3.3-android-arm64
上传到模拟器中
adb push frida-server-16.3.3-android-arm64 /data/local/tmp/
data:image/s3,"s3://crabby-images/8985c/8985c88d1d989da0ffd35a253418b42a013d2c90" alt="Untitled"
启动frida
adb shell
su
cd /data/local/tmp/
chmod +x frida-server-16.3.3-android-arm64
./frida-server-16.3.3-android-arm64
data:image/s3,"s3://crabby-images/8f04e/8f04e04736dacff7deac27b64b12c07c0c649fcb" alt="Untitled"
另起一个终端 查看模拟器进程
frida-ps -U
data:image/s3,"s3://crabby-images/a66a4/a66a4b671fde63c8d9186907d954a3cf4d03d6dd" alt="Untitled"
安装常用app
frida实战测试
对某颜色APP进行抓包 发现数据都是被加密了
data:image/s3,"s3://crabby-images/59fa0/59fa009c330dcfab5fae4bf529828f009788405a" alt="Untitled"
使用frida进行调试 打印出调用栈信息
frida -U -f "cn.mciaa.yshxcp" -l hook-js/hook-js/打印调用栈/HashMap_Hook.js
根据调用栈信息找到加密函数
data:image/s3,"s3://crabby-images/08f56/08f56ffe7f14f4775ca91cbef5fe5cad77b3c742" alt="Untitled"
使用jadx-gui进行反编译 找到Java文件 ApiEncryptUtil.java
可以看到是AES加密函数 和 解密函数
data:image/s3,"s3://crabby-images/99747/99747030d076944c7d0f5ff47f6d4317eb530c02" alt="Untitled"
编写hook脚本
调用解密函数a
data:image/s3,"s3://crabby-images/780d4/780d46c2bef11c1017fca3df35fba7e3aa6eab14" alt="Untitled"
Java.perform(function () {
var targetClass = Java.use('c.h.a.l.r');
targetClass.a.implementation = function(str) {
console.log("Original argument: "+ str);
var result = this.a(str);
console.log('Original result: ' + result);
return result;
}
});
之后载入hook脚本 发现数据已经解密
frida -U -f "cn.mciaa.yshxcp" -l decode.js
data:image/s3,"s3://crabby-images/8d2c4/8d2c49cdbff016ef7890a4a03cd90ba86ae35a18" alt="Untitled"
但是这样看非常费劲 且不能对数据包进行测试
下面使用BurpSuite插件Brida对数据包进行加解密
配置好Brida
data:image/s3,"s3://crabby-images/20f15/20f157fb7f3fbb3a7ec0f6c8a9c125fd8baf1ee9" alt="Untitled"
点击 Load JS file加载hook的js脚本
data:image/s3,"s3://crabby-images/65862/65862bab394c39e4e904b76324252e075c0309a1" alt="Untitled"
按照Brida脚本编写规则进行编写hook函数
decode:function (str) {
var ret;
Java.perform(function () {
var clazz = Java.use("c.h.a.l.r");
ret = clazz.a(str);
});
return ret;
},
encode:function (str) {
var ret;
Java.perform(function () {
var clazz = Java.use("c.h.a.l.r");
ret = clazz.b(str);
});
return ret;
},
对编写的函数进行测试
先点击Spawn application
之后把加密数据放进去点击Run export 即可看到解密后的数据
data:image/s3,"s3://crabby-images/a0d3c/a0d3c001d475c330b44834f6adf6d93c142be49b" alt="Untitled"
加密函数测试正常
data:image/s3,"s3://crabby-images/abb60/abb606c5ff155575a88ef0b3aa7b361174384985" alt="Untitled"
加入右键
data:image/s3,"s3://crabby-images/022bc/022bc3a5bbfa916171a2aa7bf831ca574cde73da" alt="Untitled"
data:image/s3,"s3://crabby-images/f86da/f86da43ee3bb731ebd427cc05aefb1335df3bd27" alt="Untitled"
data:image/s3,"s3://crabby-images/0a573/0a573a5b75f73b903a602c7552834945e34b991a" alt="Untitled"
这样测试就方便多了