吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1661|回复: 1
收起左侧

[Android 求助] xposed hook动态加载的class软件崩溃JNI ERROR

[复制链接]
zch11230 发表于 2020-3-18 15:34
之前写的个插件,因为自己无太多正式软件编程能力,一般也就用点脚本语言,跟着论坛学着写的,在软件更新之前能用,先根据软件包名过滤不需要Hook的APP,因为是动态加载的class,再XposedBridge.hookAllMethods(ClassLoader.class, "loadClass", new XC_MethodHook() hook到了需要修改的界面,再在这个界面里面用列出了所有方法,找到自己需要的数据。最近软件更新之后,插件不能用了,在APP主界面正常,因为还没有开始hook动态加载的class,再点到子界面软件就崩溃了,排查了代码,注释了所有的功能,只留了下面这段什么也没做的代码,一样的崩溃,有知道为啥的么。


public void handleLoadPackage(XC_LoadPackage.LoadPackageParam loadPackageParam) throws Throwable {
    if (!loadPackageParam.packageName.contains("com.test.app")) return;
    XposedBridge.hookAllMethods(ClassLoader.class, "loadClass", new XC_MethodHook() {
        @Override
        protected void afterHookedMethod(MethodHookParam param) throws Throwable {
            super.afterHookedMethod(param);
            if (param.hasThrowable()) return;

            Class<?> aClass = (Class<?>) param.getResult();
            if (aClass.getName().contains("com.test.app.call.activity")) {
                XposedBridge.log("hook test 1");
                XposedBridge.hookAllMethods(aClass, "onCreate", new XC_MethodHook() {
                    @Override
                    protected void afterHookedMethod(MethodHookParam param) throws Throwable {
                        super.afterHookedMethod(param);
                        XposedBridge.log("hook test 2");
                    }
                });
            }
        }
    });
}

在xposed日志中发现如下报错,第一条日志记录有,第二条没有,直接就报错了,其实啥也没做。 I/Xposed  ( 1374): hook test 1
F/art     ( 1374): art/runtime/indirect_reference_table.cc:115] JNI ERROR (app bug): local reference table overflow (max=512)
F/art     ( 1374): art/runtime/indirect_reference_table.cc:115] local reference table dump:
F/art     ( 1374): art/runtime/indirect_reference_table.cc:115]   Last 10 entries (of 512):
F/art     ( 1374): art/runtime/indirect_reference_table.cc:115]       511: 0x13379380 java.lang.String "com.test.app.... (53 chars)
F/art     ( 1374): art/runtime/indirect_reference_table.cc:115]       510: 0x12caa400 dalvik.system.PathClassLoader
F/art     ( 1374): art/runtime/indirect_reference_table.cc:115]       509: 0x12caa400 dalvik.system.PathClassLoader
F/art     ( 1374): art/runtime/indirect_reference_table.cc:115]       508: 0x1340ab40 java.lang.Object[] (1 elements)
F/art     ( 1374): art/runtime/indirect_reference_table.cc:115]       507: 0x13379380 java.lang.String "com.test.app.... (53 chars)
F/art     ( 1374): art/runtime/indirect_reference_table.cc:115]       506: 0x12caa400 dalvik.system.PathClassLoader
F/art     ( 1374): art/runtime/indirect_reference_table.cc:115]       505: 0x12caa400 dalvik.system.PathClassLoader
F/art     ( 1374): art/runtime/indirect_reference_table.cc:115]       504: 0x1343cc60 java.lang.Object[] (2 elements)
F/art     ( 1374): art/runtime/indirect_reference_table.cc:115]       503: 0x13379280 java.lang.String "com.test.app.... (53 chars)
F/art     ( 1374): art/runtime/indirect_reference_table.cc:115]       502: 0x12caa400 dalvik.system.PathClassLoader
F/art     ( 1374): art/runtime/indirect_reference_table.cc:115]   Summary:
F/art     ( 1374): art/runtime/indirect_reference_table.cc:115]        63 of java.lang.Object[] (1 elements) (63 unique instances)
F/art     ( 1374): art/runtime/indirect_reference_table.cc:115]        62 of java.lang.Object[] (2 elements) (62 unique instances)
F/art     ( 1374): art/runtime/indirect_reference_table.cc:115]         5 of java.lang.Class (4 unique instances)
F/art     ( 1374): art/runtime/indirect_reference_table.cc:115]         1 of java.lang.String[] (3 elements)
F/art     ( 1374): art/runtime/indirect_reference_table.cc:115]       129 of java.lang.String (66 unique instances)
F/art     ( 1374): art/runtime/indirect_reference_table.cc:115]       252 of dalvik.system.PathClassLoader (1 unique instances)
F/art     ( 1374): art/runtime/indirect_reference_table.cc:115]
F/art     ( 1374): art/runtime/barrier.cc:90] Check failed: count_ == 0 (count_=-1, 0=0) Attempted to destroy barrier with non zero count
F/art     ( 1374): art/runtime/runtime.cc:372] Runtime aborting --- recursively, so no thread-specific detail!
F/art     ( 1374): art/runtime/runtime.cc:372]

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

看,六眼飞鱼 发表于 2020-3-18 17:54
加油,帮顶
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-16 00:23

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表