其他分享
首页 > 其他分享> > android-通过意外的DEX解析的类;

android-通过意外的DEX解析的类;

作者:互联网

我正在开发一个应用程序,该应用程序会自动从外部apk文件中的外部dex加载类(外部apk文件存储在应用程序的内部存储中).外部apk文件具有使用com.google.gson的类.

应用程序的源代码

// Internal storage where the DexClassLoader writes the optimized dex file to.
    final File optimizedDexOutputPath = mContext.getDir("optimize_offload", Context.MODE_PRIVATE);

    // Initialize the class loader with the s dex file.
    DexClassLoader dexClassLoader = new DexClassLoader(apkPath,  optimizedDexOutputPath.getAbsolutePath(),
            null,  mContext.getClassLoader());

    // Load the apk class from the class loader.
    Class<?> apkProviderClass = dexClassLoader.loadClass(className);        

    Object obj = apkProviderClass.newInstance();   

    // call method wrappers
    java.lang.reflect.Method method = apkProviderClass.getDeclaredMethod("R_" + methodName, String.class);
    System.out.println(method.getName());

    method.setAccessible(true); 

    Object result = method.invoke(obj, params); // Exception here

外部apk文件中的类具有以下方法

public long R_catalanSum(String params) {

    Gson gson = new Gson();

    StartedSumLooperService_catalanSum param = 
            gson.fromJson(params, StartedSumLooperService_catalanSum.class);

    // Call local implementation
    return catalanSum(param.n); 
}

public long R_fiboSum(String params) {

    Gson gson = new Gson();

    StartedSumLooperService_fiboSum param = 
            gson.fromJson(params, StartedSumLooperService_fiboSum.class);

    // Call local implementation
    return fiboSum(param.n); 
}

但是我在运行时面临以下问题:

03-05 17:10:59.479: W/dalvikvm(5433): Class resolved by unexpected DEX: Lorg/vkedco/android/startedsumlooperservice/StartedSumLooperService;(0x40f007d8):0x56f3a000 ref [Lcom/google/gson/Gson;] Lcom/google/gson/Gson;(0x40eabac0):0x56daa000

03月5日17:10:59.479:W / dalvikvm(5433):( Lorg / vkedco / android / startedsumlooperservice / StartedSumLooperService;在预验证期间使用了其他Lcom / google / gson / Gson;)

根据Android的构建过程,dex文件与3rd party库(例如此处的gson)一起捆绑到dex文件(classes.dex)中.因此,在使用DexClassLoader初始化类加载器时,我不需要手动指定所有第3个库.我说的对吗?

解决方法:

这个问题的答案是DEX在类加载器和已加载的类中找到gson的2个版本.
解决方案是:仅在类加载器或已加载的类中使用gson.

标签:reflection,android,dex,dexclassloader
来源: https://codeday.me/bug/20191122/2056411.html