使用 ProGuard 时不起作用

Posted

技术标签:

【中文标题】使用 ProGuard 时不起作用【英文标题】:Does not work when use ProGuard 【发布时间】:2013-07-23 09:06:38 【问题描述】:

logcat 如下。怎么了?

07-24 10:54:13.529:E/androidRuntime(12130):致命异常:AsyncTask #3

07-24 10:54:13.529: E/AndroidRuntime(12130): java.lang.RuntimeException: 执行 doInBackground() 时出错

07-24 10:54:13.529: E/AndroidRuntime(12130): 在 android.os.AsyncTask$3.done(AsyncTask.java:299)

07-24 10:54:13.529: E/AndroidRuntime(12130): at java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:273)

07-24 10:54:13.529: E/AndroidRuntime(12130): at java.util.concurrent.FutureTask.setException(FutureTask.java:124)

07-24 10:54:13.529: E/AndroidRuntime(12130): at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:307)

07-24 10:54:13.529: E/AndroidRuntime(12130): at java.util.concurrent.FutureTask.run(FutureTask.java:137)

07-24 10:54:13.529: E/AndroidRuntime(12130): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)

07-24 10:54:13.529: E/AndroidRuntime(12130): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)

07-24 10:54:13.529: E/AndroidRuntime(12130): at java.lang.Thread.run(Thread.java:856)

07-24 10:54:13.529: E/AndroidRuntime(12130): Caused by: java.lang.AssertionError: 非法类型变量引用

07-24 10:54:13.529: E/AndroidRuntime(12130): at org.apache.harmony.luni.lang.reflect.ImplForVariable.resolve(ImplForVariable.java:113)

07-24 10:54:13.529:E/AndroidRuntime(12130):在 org.apache.harmony.luni.lang.reflect.ImplForVariable.getGenericDeclaration(ImplForVariable.java:127)

07-24 10:54:13.529: E/AndroidRuntime(12130): at org.apache.harmony.luni.lang.reflect.ImplForVariable.hashCode(ImplForVariable.java:46)

07-24 10:54:13.529: E/AndroidRuntime(12130): at java.util.Arrays.hashCode(Arrays.java:1260)

07-24 10:54:13.529: E/AndroidRuntime(12130): at com.google.gson.internal.$Gson$Types$ParameterizedTypeImpl.hashCode(SourceFile:475)

07-24 10:54:13.529: E/AndroidRuntime(12130): at com.google.gson.reflect.TypeToken.(SourceFile:64)

07-24 10:54:13.529: E/AndroidRuntime(12130): at com.gaozhi.wh.asynctask.MyAsyncTask$2$1.(SourceFile:78)

07-24 10:54:13.529: E/AndroidRuntime(12130): at com.gaozhi.wh.asynctask.MyAsyncTask$2.call(SourceFile:78)

07-24 10:54:13.529: E/AndroidRuntime(12130): at com.gaozhi.wh.asynctask.MyAsyncTask$2.call(SourceFile:1)

07-24 10:54:13.529: E/AndroidRuntime(12130): at com.gaozhi.wh.utils.async.AsyncTaskUtils$2.doInBackground(SourceFile:114)

07-24 10:54:13.529: E/AndroidRuntime(12130): at com.gaozhi.wh.utils.async.AsyncTaskUtils$2.doInBackground(SourceFile:1)

07-24 10:54:13.529: E/AndroidRuntime(12130): 在 android.os.AsyncTask$2.call(AsyncTask.java:287)

07-24 10:54:13.529: E/AndroidRuntime(12130): 在 java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305) 07-24 10:54:13.529: E/AndroidRuntime(12130): ... 4 更多

我发现是这行代码错误引起的

info = GsonUtils.getMutileBean(result,new TypeToken<JsonResult<T>>() .getType());

public static <T> T getMutileBean(String jsonData, Type type)
        throws Exception 
    return new Gson().fromJson(jsonData, type);

.

但是我已经为 Gson 添加了 proguard 配置

# Gson 在处理字段时使用存储在类文件中的泛型类型信息。警卫队

#默认会移除此类信息,所以配置为保留全部。

-keepattributes 签名

# 用于使用 GSON @Expose 注解

-keepattributes 注解

# Gson 特定类

-保持类 sun.misc.Unsafe *;

#-keep class com.google.gson.stream.** *;

# 将通过 Gson 序列化/反序列化的应用程序类

-keep class com.google.gson.examples.android.model.** *;

【问题讨论】:

如何在 AsyncTask 中使用反射?也许 proguard.cfg 错过了反射类? 【参考方案1】:

您可能需要添加

-keepattributes EnclosingMethod

【讨论】:

我仍然有这个错误,这里有什么帮助吗? ***.com/questions/48198040/…【参考方案2】:

EnclosingMethod 添加到 proguard 配置对我没有帮助。

但是,通过保留属性 InnerClasses,我能够构建一个正常运行的 APK

【讨论】:

以上是关于使用 ProGuard 时不起作用的主要内容,如果未能解决你的问题,请参考以下文章

Android 中的 ProGuard 不起作用。(不混淆)

启用 ProGuard 规则时 Gson 解析不起作用

proguard.cfg 在使用 LIBRARY 的导出应用程序中不起作用

在 proguard 之后,点击在发布 apk 中不起作用

在 gradle 中启用 Proguard 后 FCM 不起作用

将scala代码打包到一个jar文件中,proguard不起作用