Не удается загрузить класс из apk с помощью DexClassLoader - PullRequest
0 голосов
/ 08 января 2019

Я пытаюсь загрузить класс динамически из файла dex. Каждый раз, когда я вызываю loadClass, я получаю ClassNotFoundException. Файл apk существует и является действительным (Android Studio может прочитать его и увидеть все классы). Он находится в локальном хранилище, так что это не должно быть проблемой с разрешениями (но я попросил разрешение на внешнее хранение на всякий случай). Если я пытаюсь загрузить класс, который находится в java.lang или android. *, Он работает, кажется, что он не работает только для моего пакета. Есть идеи, что не так?

Код:

private void loadApk(File libFile, String classname) {
    try {
        DexClassLoader classloader = new DexClassLoader(
                libFile.getAbsolutePath(), getCodeCacheDir().getAbsolutePath(),
                null,
                getClassLoader());

        Class<?> classToLoad = (Class<?>) classloader
                .loadClass("com.gabesechansoftware.testloadedapk.LoadedClass");

        Constructor<?> constructor = classToLoad.getConstructor();
        Object object = constructor.newInstance();

        Log.d("Gabe", "object is " + object);
    } catch (Exception ex) {
        throw new RuntimeException(ex);
    }
}
...
loadApk(new File(getFilesDir(), "app-debug.apk"), "com.gabesechansoftware.testloadedapk.LoadedClass");

Исключение:

     Caused by: java.lang.RuntimeException: java.lang.ClassNotFoundException: Didn't find class "com.gabesechansoftware.testloadedapk.LoadedClass" on path: DexPathList[[zip file "/data/user/0/com.gabesechansoftware.apkloader/files/app-debug.apk"],nativeLibraryDirectories=[/system/lib, /vendor/lib]]
    at com.gabesechansoftware.apkloader.MainActivity.loadApk(MainActivity.java:58)
    at com.gabesechansoftware.apkloader.MainActivity.onCreate(MainActivity.java:39)
    at android.app.Activity.performCreate(Activity.java:6975)
    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1213)
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2770)
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2892) 
    at android.app.ActivityThread.-wrap11(Unknown Source:0) 
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1593) 
    at android.os.Handler.dispatchMessage(Handler.java:105) 
    at android.os.Looper.loop(Looper.java:164) 
    at android.app.ActivityThread.main(ActivityThread.java:6541) 
    at java.lang.reflect.Method.invoke(Native Method) 
    at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:767) 
 Caused by: java.lang.ClassNotFoundException: Didn't find class "com.gabesechansoftware.testloadedapk.LoadedClass" on path: DexPathList[[zip file "/data/user/0/com.gabesechansoftware.apkloader/files/app-debug.apk"],nativeLibraryDirectories=[/system/lib, /vendor/lib]]
    at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:93)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:379)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:312)
    at com.gabesechansoftware.apkloader.MainActivity.loadApk(MainActivity.java:51)
    at com.gabesechansoftware.apkloader.MainActivity.onCreate(MainActivity.java:39) 
    at android.app.Activity.performCreate(Activity.java:6975) 
    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1213) 
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2770) 
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2892) 
    at android.app.ActivityThread.-wrap11(Unknown Source:0) 
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1593) 
    at android.os.Handler.dispatchMessage(Handler.java:105) 
    at android.os.Looper.loop(Looper.java:164) 
    at android.app.ActivityThread.main(ActivityThread.java:6541) 
    at java.lang.reflect.Method.invoke(Native Method) 
    at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:767) 
    Suppressed: java.io.IOException: No original dex files found for dex location /data/user/0/com.gabesechansoftware.apkloader/files/app-debug.apk
    at dalvik.system.DexFile.openDexFileNative(Native Method)
    at dalvik.system.DexFile.openDexFile(DexFile.java:353)
    at dalvik.system.DexFile.<init>(DexFile.java:100)
    at dalvik.system.DexFile.<init>(DexFile.java:74)
    at dalvik.system.DexPathList.loadDexFile(DexPathList.java:374)
    at dalvik.system.DexPathList.makeDexElements(DexPathList.java:337)
    at dalvik.system.DexPathList.<init>(DexPathList.java:157)
    at dalvik.system.BaseDexClassLoader.<init>(BaseDexClassLoader.java:65)
    at dalvik.system.DexClassLoader.<init>(DexClassLoader.java:57)
    at com.gabesechansoftware.apkloader.MainActivity.loadApk(MainActivity.java:48)
            ... 13 more

Он также создает файл app-debug.apk.prof, так что он определенно находит apk

...