启用 Proguard 后“应用程序停止工作”

Posted

技术标签:

【中文标题】启用 Proguard 后“应用程序停止工作”【英文标题】:"Application stopped working" after enabling Proguard 【发布时间】:2012-12-16 04:14:33 【问题描述】:

这是一个可以运行的应用程序,无论是在模拟器上还是在我正在测试的设备上。

但是现在,我启用了 Proguard 并使用 android-Tools > Export signed application 导出了签名的应用程序

然后我将此.apk 复制到 SD 卡上并尝试安装在设备上。但是应用程序停止工作,如果我尝试打开它,要求强制关闭。

如果我从 Eclipse 运行,它可以在设备上运行。

既然这样说:

Proguard 仅在您导出发行版 .apk 文件时有效。我检查了一下,bin文件夹中的apk文件大小是1.8mb,而我导出后得到的1是1.4mb。似乎 Proguard 已经完成了它的工作。但该应用程序无法正常工作。可悲的是我看不到任何日志等,

编辑:

如果我禁用 Proguard 然后导出,则发布的 apk 文件现在可以正常工作。那么,Proguard 有什么问题吗?

我的文件夹结构

proguard-project.txt

# This is a configuration file for ProGuard.
# http://proguard.sourceforge.net/index.html#manual/usage.html

-dontusemixedcaseclassnames
-dontskipnonpubliclibraryclasses
-verbose

# Optimization is turned off by default. Dex does not like code run
# through the ProGuard optimize and preverify steps (and performs some
# of these optimizations on its own).
-dontoptimize
-dontpreverify
# Note that if you want to enable optimization, you cannot just
# include optimization flags in your own project configuration file;
# instead you will need to point to the
# "proguard-android-optimize.txt" file instead of this one from your
# project.properties file.

-keepattributes *Annotation*
-keep public class com.google.vending.licensing.ILicensingService
-keep public class com.android.vending.licensing.ILicensingService
-keep public class * extends android.app.Application
-keep public class * extends android.app.Activity
-keep public class * extends android.app.PreferenceActivity
-keep public class * extends android.view.View
-keep public class * extends android.widget.BaseAdapter
-keep public class * extends android.app.Service
-keep public class * extends android.content.BroadcastReceiver
-keep public class * implements android.view.View.OnTouchListener
-keep public class * implements android.view.View.OnClickListener
-keep public class * extends com.actionbarsherlock.app.SherlockActivity
-keep public class * extends com.actionbarsherlock.app.SherlockFragmentActivity
-keep public class * extends com.actionbarsherlock.app.SherlockMapActivity
-keep public class * extends com.readystatesoftware.mapviewballoons.BalloonItemizedOverlay<OverlayItem>
-keep public class * extends com.actionbarsherlock.app.SherlockFragment


-libraryjars libs/android-support-v4.jar
-libraryjars libs/apache-mime4j-0.6.jar
-libraryjars libs/httpmime-4.0.1.jar
-libraryjars libs/libGoogleAnalyticsV2.jar  



-assumenosideeffects class android.util.Log 
    public static *** v(...);
    public static *** i(...);
    public static *** d(...);
    public static *** w(...);
    public static *** e(...);


# For native methods, see http://proguard.sourceforge.net/manual/examples.html#native
-keepclasseswithmembernames class * 
    native <methods>;


# keep setters in Views so that animations can still work.
# see http://proguard.sourceforge.net/manual/examples.html#beans
-keepclassmembers public class * extends android.view.View 
   void set*(***);
   *** get*();


# We want to keep methods in Activity that could be used in the XML attribute onClick
-keepclassmembers class * extends android.app.Activity 
   public void *(android.view.View);


# For enumeration classes, see http://proguard.sourceforge.net/manual/examples.html#enumerations
-keepclassmembers enum * 
    public static **[] values();
    public static ** valueOf(java.lang.String);


-keep class * implements android.os.Parcelable 
  public static final android.os.Parcelable$Creator *;


-keepclassmembers class **.R$* 
    public static <fields>;


# The support library contains references to newer platform versions.
# Don't warn about those in case this app is linking against an older
# platform version.  We know about them, and they are safe.
-dontwarn android.support.**
-dontwarn org.apache.**

我今天才开始使用它,我不确定我是否以正确的方式使用它。所以,如果我在任何地方错了,请纠正我。

这是 LogCat 错误:

01-02 13:18:54.711: E/AndroidRuntime(585): java.lang.RuntimeException: Unable to start activity ComponentInfocom.xApp.app/com.xApp.app.LandingActivity: java.lang.RuntimeException: java.lang.NoSuchMethodException: a(Activity,int)
01-02 13:18:54.711: E/AndroidRuntime(585):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647)
01-02 13:18:54.711: E/AndroidRuntime(585):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
01-02 13:18:54.711: E/AndroidRuntime(585):  at android.app.ActivityThread.access$1500(ActivityThread.java:117)
01-02 13:18:54.711: E/AndroidRuntime(585):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
01-02 13:18:54.711: E/AndroidRuntime(585):  at android.os.Handler.dispatchMessage(Handler.java:99)
01-02 13:18:54.711: E/AndroidRuntime(585):  at android.os.Looper.loop(Looper.java:130)
01-02 13:18:54.711: E/AndroidRuntime(585):  at android.app.ActivityThread.main(ActivityThread.java:3683)
01-02 13:18:54.711: E/AndroidRuntime(585):  at java.lang.reflect.Method.invokeNative(Native Method)
01-02 13:18:54.711: E/AndroidRuntime(585):  at java.lang.reflect.Method.invoke(Method.java:507)
01-02 13:18:54.711: E/AndroidRuntime(585):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
01-02 13:18:54.711: E/AndroidRuntime(585):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
01-02 13:18:54.711: E/AndroidRuntime(585):  at dalvik.system.NativeStart.main(Native Method)
01-02 13:18:54.711: E/AndroidRuntime(585): Caused by: java.lang.RuntimeException: java.lang.NoSuchMethodException: a(Activity,int)
01-02 13:18:54.711: E/AndroidRuntime(585):  at com.actionbarsherlock.a.a(Unknown Source)
01-02 13:18:54.711: E/AndroidRuntime(585):  at com.actionbarsherlock.app.SherlockActivity.a(Unknown Source)
01-02 13:18:54.711: E/AndroidRuntime(585):  at com.actionbarsherlock.app.SherlockActivity.setContentView(Unknown Source)
01-02 13:18:54.711: E/AndroidRuntime(585):  at com.xApp.app.LandingActivity.onCreate(Unknown Source)
01-02 13:18:54.711: E/AndroidRuntime(585):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
01-02 13:18:54.711: E/AndroidRuntime(585):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
01-02 13:18:54.711: E/AndroidRuntime(585):  ... 11 more
01-02 13:18:54.711: E/AndroidRuntime(585): Caused by: java.lang.NoSuchMethodException: a(Activity,int)
01-02 13:18:54.711: E/AndroidRuntime(585):  at java.lang.Class.getMatchingConstructor(Class.java:643)
01-02 13:18:54.711: E/AndroidRuntime(585):  at java.lang.Class.getConstructor(Class.java:472)
01-02 13:18:54.711: E/AndroidRuntime(585):  ... 17 more

谢谢

【问题讨论】:

是的,我已经这样做了 3-4 次。什么都没解决。实际上禁用 Proguard 是可行的。所以,我认为问题出在 Proguard,而不是导出 与大多数无法解释的崩溃/强制关闭一样,除非您发布崩溃中的 logcat 错误,否则人们无法帮助您。这将提供关键线索,说明 proguard 操作中的哪些问题,以及 proguard 配置中需要更改的内容。 你看过这个教程了吗developer.android.com/tools/help/proguard.html @ChrisStratton 但我如何获取日志?我应该从配置文件中删除 Logs 相关代码 并在 Emulator 上安装 apk 吗? @TomerMor 是的,我彻底阅读了该文档,但是我遇到了一些问题,例如在我的项目中找不到 proguard.cfg 文件,所以我遵循了这个答案 @987654322 @。他说文档已经过时了,基本上他们将以前的 proguard.cfg 分成两个文件(并且还简单地将它们制作为 .txt 文件):proguard-android.txt 和 proguard-project.txt。 【参考方案1】:

堆栈跟踪显示 ActionBarSherlock 无法使用反射找到构造函数“a(Activity,int)”。它的文档确实指定了 ActionBarSherlock 的每个扩展都应该有这样的构造函数。 ProGuard 不(不能)知道这一点并删除了构造函数,因为它在代码中似乎未使用。因此,您必须明确告诉 ProGuard 保留它:

-keepclassmembers class * extends com.actionbarsherlock.ActionBarSherlock 
    <init>(android.app.Activity, int);

一般来说,如果你在你的代码或者它的库中得到这样的与反射相关的堆栈跟踪,你需要添加相应的配置。

【讨论】:

以上是关于启用 Proguard 后“应用程序停止工作”的主要内容,如果未能解决你的问题,请参考以下文章

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

启用 proguard 后 java.lang.NoSuchMethodError Org/apache/http/util/ByteArrayBuffer

启用 Proguard 后无法实例化片段

启用 proguard 后无法访问 kotlin 类中使用的伴随对象

启用proguard后Realm中的ClassNotFoundException

启用 PROGUARD - Xamarin.Android