首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Android \ DexClassLoader,ClassNotFound异常

Android \ DexClassLoader,ClassNotFound异常
EN

Stack Overflow用户
提问于 2016-04-12 06:20:38
回答 2查看 3K关注 0票数 1

因此,我试图加载我从应用程序中编写的类,但我收到了ClassNotFound异常。

类:

代码语言:javascript
运行
复制
public class myclass{
    public String doSomething()
    {
        return "Hello from myclass";
    }
}

我使用以下命令创建jar文件:

代码语言:javascript
运行
复制
javac myclass.java
jar cvf myclass.jar myclass.class

下一步是为jar文件创建一个classes.dex,并将其添加到jar中:

代码语言:javascript
运行
复制
dx --dex --output=classes.dex myclass.jar
aapt add myclass.jar classes.dex

直到现在,一切都很好,没有错误。

在这一步的末尾,jar文件如下所示:

代码语言:javascript
运行
复制
myclass.jar
    -> classes.dex
    -> myclass.class
    -> META-INF
       -> MANIFEST.MF

我的清单文件包含以下行:

代码语言:javascript
运行
复制
Manifest-Version: 1.0
Created-By: 1.7.0_79 (Oracle Corporation)

现在,在我的应用程序中,我正在执行以下操作:

代码语言:javascript
运行
复制
private void activate()
{
    try {
        URL url;
        final String libPath = Environment.getExternalStorageDirectory() + "/myclass.jar";
        final File tmpDir = getDir("dex", 0);

        final DexClassLoader classloader = new DexClassLoader(libPath, tmpDir.getAbsolutePath(), null, this.getClass().getClassLoader());
        final Class<Object> classToLoad = (Class<Object>) classloader.loadClass("myclass");

        final Object myInstance  = classToLoad.newInstance();
        final Method doSomething = classToLoad.getMethod("doSomething");

        String result = (String)doSomething.invoke(myInstance);
        Toast.makeText(MainActivity.this, String.valueOf(result), Toast.LENGTH_SHORT).show();
    } catch (Exception e) {
        e.printStackTrace();
    }
}

备注:

  1. 我将myclass.jar文件复制到

Environment.getExternalStorageDirectory()

目录和我确认应用程序正在正确读取文件。

  1. 我已经在清单文件中设置了所需的权限(读和写到外部存储)

给出错误的行是:

代码语言:javascript
运行
复制
final Class<Object> classToLoad = (Class<Object>) classloader.loadClass("myclass");

错误:

代码语言:javascript
运行
复制
Didn't find class "myclass" on path: DexPathList[[zip file "/storage/emulated/0/myclass.jar"],nativeLibraryDirectories=[/vendor/lib, /system/lib]]

这是被抑制的例外情况:

代码语言:javascript
运行
复制
java.io.IOException: No original dex files found for dex location /storage/emulated/0/myclass.jar

java.lang.ClassNotFoundException: Didn't find class "myclass" on path: DexPathList[[dex file "/data/data/hayzohar.testingclassloaders/files/instant-run/dex/slice-support-annotations-23.3.0_d42c1a3ea55c8ce3f82fc6c8adde2e2271b97d01-classes.dex", dex file "/data/data/hayzohar.testingclassloaders/files/instant-run/dex/slice-slice_9-classes.dex", dex file "/data/data/hayzohar.testingclassloaders/files/instant-run/dex/slice-slice_8-classes.dex", dex file "/data/data/hayzohar.testingclassloaders/files/instant-run/dex/slice-slice_7-classes.dex", dex file "/data/data/hayzohar.testingclassloaders/files/instant-run/dex/slice-slice_6-classes.dex", dex file "/data/data/hayzohar.testingclassloaders/files/instant-run/dex/slice-slice_5-classes.dex", dex file "/data/data/hayzohar.testingclassloaders/files/instant-run/dex/slice-slice_4-classes.dex", dex file "/data/data/hayzohar.testingclassloaders/files/instant-run/dex/slice-slice_3-classes.dex", dex file "/data/data/hayzohar.testingclassloaders/files/instant-run/dex/slice-slice_2-classes.dex", dex file "/data/data/hayzohar.testingclassloaders/files/instant-run/dex/slice-slice_1-classes.dex", dex file "/data/data/hayzohar.testingclassloaders/files/instant-run/dex/slice-slice_0-classes.dex", dex file "/data/data/hayzohar.testingclassloaders/files/instant-run/dex/slice-internal_impl-23.3.0_75eb76bdd9c015b48a4280667bfd60eddc59734a-classes.dex", dex file "/data/data/hayzohar.testingclassloaders/files/instant-run/dex/slice-com.android.support-support-vector-drawable-23.3.0_0a5b88d45587f58c7ea931638fd9c9d6c4641bc7-classes.dex", dex file "/data/data/hayzohar.testingclassloaders/files/instant-run/dex/slice-com.android.support-support-v4-23.3.0_a0a32aaad2874bf2c15ffa67543dfe5af5b91a95-classes.dex", dex file "/data/data/hayzohar.testingclassloaders/files/instant-run/dex/slice-com.android.support-appcompat-v7-23.3.0_eae70f9c3956161dfb324670cb40cb42e6e1b16a-classes.dex", dex file "/data/data/hayzohar.testingclassloaders/files/instant-run/dex/slice-com.android.support-animated-vector-drawable-23.3.0_d4513d6bda757fa567bc4d7ea3e4bb7cbd09c077-classes.dex"],nativeLibraryDirectories=[/data/app/hayzohar.testingclassloaders-2/lib/x86, /vendor/lib, /system/lib]]

我做错什么了?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-04-13 08:04:42

在深入研究了这些代码之后,我发现问题在于权限。模拟器让Android 6在上面运行,gradle文件中的目标sdk被设置为23,这意味着我们必须请求运行时权限。

说到底,问题是没有权限读取文件。

如果有人面临这个问题,并且正在使用android 6运行模拟器,请确保您请求运行时权限(清单是不够的),或者您只需要将目标sdk设置为version 22及更低版本。

票数 4
EN

Stack Overflow用户

发布于 2016-04-13 05:58:21

您可以在不同的论坛中读取的一件事是,该文件必须在应用程序文件夹中可用。因此,使用以下方法存储jar文件:

代码语言:javascript
运行
复制
File jarFile = new File(getDir([WHATEVERY_YOU_WANT_FOLDER_NAME], Context.MODE_PRIVATE), [JAR_FILE_NAME]);

到目前为止就是这样。希望它能帮助解决你的问题。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36565032

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档