Frida Hook 指定Classloader

最近使用Frida 进行Hook 时,遇到一个问题。
某些应用,会有自己的Classloader进行动态加载,而Frida是使用的默认的Classloader
无法hook。使用下面方法可以指定Frida使用的Classloader。

 Java.enumerateClassLoaders({
    onMatch: function (loader) {
        try {
            // the apk contains class: org.chromium.net.AndroidNetworkLibrary
            if (loader.findClass("org.chromium.net.AndroidNetworkLibrary")) {
                console.log('AndroidNetworkLibrary ', loader.toString())
                //判断classloader路径是不是你想要的
                if (loader.toString().indexOf("google") != -1) {
                    Java.classFactory.loader = loader;
                    send("loader: " + loader);
                    hookWebview()
                    // [*] loader: dalvik.system.DelegateLastClassLoader[DexPathList[[zip file "/data/user_de/0/com.google.android.gms/app_chimera/m/00000009/CronetDynamite.apk"],nativeLibraryDirectories=[/data/user_de/0/com.google.android.gms/app_chimera/m/00000009/CronetDynamite.apk!/lib/arm64-v8a, /system/lib64, /system/product/lib64]]]
                }
            }
        } catch (error) {
        }
    }, onComplete: function () {
    }
  });

注意:
即使使用这个方法,也得等动态加载机制已经开始加载了,才能进行Hook

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值