Android 应用程序在启用 Proguard 时崩溃
Android app crashes when Proguard is enabled
每次我从 eclipse 导出签名应用程序并将 apk 文件安装到我的 phone 时,应用程序都会崩溃。这只会在启用 Proguard 时发生。
这是我的proguard文件
-libraryjars /libs/firebase-client-android-2.2.3.jar
-libraryjars /libs/android-support-v4.jar
-optimizationpasses 5
-dontusemixedcaseclassnames
-dontskipnonpubliclibraryclasses
-dontpreverify
-verbose
-optimizations !code/simplification/arithmetic,!field/*,!class/merging/*
-keep public class * extends android.app.Activity
-keep public class * extends android.app.Application
-keep public class * extends android.app.Service
-keep public class * extends android.content.BroadcastReceiver
-keep public class * extends android.content.ContentProvider
-keep public class * extends android.app.backup.BackupAgentHelper
-keep public class * extends android.preference.Preference
-keep public class com.android.vending.licensing.ILicensingService
-keep public class * implements java.io.Serializable
-keep public class * extends android.support.v4.app.Fragment
-keep public class * extends android.support.v4.app.ListFragment
-dontwarn com.shaded.fasterxml.**
-dontwarn org.apache.**
-dontwarn org.shaded.apache.**
-keepnames class com.shaded.fasterxml.jackson.** { *; }
-keepnames class org.shaded.apache.**
-keepnames interface com.fasterxml.jackson.** {
*;
}
-keep public class * extends com.android.partysearch.ChatApplication
-keepclassmembers class * extends com.android.partysearch.ChatApplication{
public <init>(android.content.Context);
}
-keep public class org.spongycastle.** {
<fields>;
<methods>;
}
-keep public class org.apache.** {
<fields>;
<methods>;
}
-ignorewarnings
-keepclasseswithmembernames class * {
native <methods>;
}
-keepclasseswithmembers class * {
public <init>(android.content.Context, android.util.AttributeSet);
}
-keepclasseswithmembers class * {
public <init>(android.content.Context, android.util.AttributeSet, int);
}
-keepclassmembers class * extends android.app.Activity {
public void *(android.view.View);
}
-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 * implements java.io.Serializable {
static final long serialVersionUID;
private static final java.io.ObjectStreamField[] serialPersistentFields;
private void writeObject(java.io.ObjectOutputStream);
private void readObject(java.io.ObjectInputStream);
java.lang.Object writeReplace();
java.lang.Object readResolve();
}
我用运行adblogcat命令检查崩溃报告。以下是我认为重要的报告片段:
E/AndroidRuntime(28630): Caused by: java.lang.RuntimeException: Something went wrong, please report to support@firebase.com
E/AndroidRuntime(28630): at com.firebase.client.core.h.a(Unknown Source)
E/AndroidRuntime(28630): at com.firebase.client.g.a(Unknown Source)
E/AndroidRuntime(28630): at com.partysearch.ChatApplication.onCreate(Unknown Source)
E/AndroidRuntime(28630): at android.app.Instrumentation.callApplicationOnCreate(Instrumentation.java:1024)
E/AndroidRuntime(28630): at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4694)
E/AndroidRuntime(28630): ... 10 more
E/AndroidRuntime(28630): Caused by: java.lang.NoSuchMethodException: <init> [class android.content.Context]
E/AndroidRuntime(28630): at java.lang.Class.getConstructorOrMethod(Class.java:423)
E/AndroidRuntime(28630): at java.lang.Class.getConstructor(Class.java:397)
E/AndroidRuntime(28630): ... 15 more
第二个片段:
W/System.err( 356): Caused by: libcore.io.ErrnoException: open failed: ENOENT (No such file or directory)
W/System.err( 356): at libcore.io.Posix.open(Native Method)
W/System.err( 356): at libcore.io.BlockGuardOs.open(BlockGuardOs.java:110)
W/System.err( 356): at libcore.io.IoBridge.open(IoBridge.java:393)
W/System.err( 356): ... 8 more
如果有人能帮助我,我将不胜感激并接受你的回答。
更新:
所以我将这些添加到我的 proguard 文件中
-keepattributes Signature
-keep class com.firebase.** { *; }
-keep class org.apache.** { *; }
-keepnames class javax.servlet.** { *; }
-keepnames class org.ietf.jgss.** { *; }
-dontwarn org.w3c.dom.**
-dontwarn org.joda.time.**
-dontwarn org.ietf.jgss.**
现在我在启用 Proguard 时遇到了与 Jackson 相关的错误。如果 Proguard 被禁用,该应用程序仍然可以工作。这是崩溃日志的片段:
E/AndroidRuntime( 6032): Caused by: com.shaded.fasterxml.jackson.databind.exc.UnrecognizedPropertyException: Unrecognized field "time" (class com.partysearch.Room), not marked as ignorable (5 known properties: , "note", "level", "userName", "console", "gametype"])
E/AndroidRuntime( 6032): at [Source: java.io.StringReader@42664098; line: 1, column: 51] (through reference chain: com.partysearch.Room["time"])
E/AndroidRuntime( 6032): at com.shaded.fasterxml.jackson.databind.DeserializationContext.reportUnknownProperty(DeserializationContext.java:555)
E/AndroidRuntime( 6032): at com.shaded.fasterxml.jackson.databind.deser.std.StdDeserializer.handleUnknownProperty(StdDeserializer.java:708)
E/AndroidRuntime( 6032): at com.shaded.fasterxml.jackson.databind.deser.BeanDeserializerBase.handleUnknownProperty(BeanDeserializerBase.java:1160)
E/AndroidRuntime( 6032): at com.shaded.fasterxml.jackson.databind.deser.BeanDeserializer.deserializeFromObject(BeanDeserializer.java:315)
E/AndroidRuntime( 6032): at com.shaded.fasterxml.jackson.databind.deser.BeanDeserializer.deserialize(BeanDeserializer.java:121)
E/AndroidRuntime( 6032): at com.shaded.fasterxml.jackson.databind.ObjectMapper._readMapAndClose(ObjectMapper.java:2888)
E/AndroidRuntime( 6032): at com.shaded.fasterxml.jackson.databind.ObjectMapper.readValue(ObjectMapper.java:2034)
E/AndroidRuntime( 6032): at com.firebase.client.DataSnapshot.getValue(DataSnapshot.java:184)
E/AndroidRuntime( 6032): ... 13 more
我敢猜测您的应用程序中的某些内容正在使用 Java 反射来实例化 class。
看来 class 这已经被 proguard 改名了。
您必须找出哪一个并为其添加例外规则。
您可以使用 proguard 创建的映射文件来确定在异常中使用了哪个 class 和方法。该文件位于 build/outputs/proguard/release/mapping.txt
我终于解决了。这是我忘记添加到我的 Proguard 文件中的内容。吸气剂和吸气剂。
-keep public class com.example.YourModelClassName {
public *** get*();
public void set*(***);
}
只需在您的 proguard-rules.pro 文件中添加 -keep class com.firebase.**{ *; }
。
每次我从 eclipse 导出签名应用程序并将 apk 文件安装到我的 phone 时,应用程序都会崩溃。这只会在启用 Proguard 时发生。
这是我的proguard文件
-libraryjars /libs/firebase-client-android-2.2.3.jar
-libraryjars /libs/android-support-v4.jar
-optimizationpasses 5
-dontusemixedcaseclassnames
-dontskipnonpubliclibraryclasses
-dontpreverify
-verbose
-optimizations !code/simplification/arithmetic,!field/*,!class/merging/*
-keep public class * extends android.app.Activity
-keep public class * extends android.app.Application
-keep public class * extends android.app.Service
-keep public class * extends android.content.BroadcastReceiver
-keep public class * extends android.content.ContentProvider
-keep public class * extends android.app.backup.BackupAgentHelper
-keep public class * extends android.preference.Preference
-keep public class com.android.vending.licensing.ILicensingService
-keep public class * implements java.io.Serializable
-keep public class * extends android.support.v4.app.Fragment
-keep public class * extends android.support.v4.app.ListFragment
-dontwarn com.shaded.fasterxml.**
-dontwarn org.apache.**
-dontwarn org.shaded.apache.**
-keepnames class com.shaded.fasterxml.jackson.** { *; }
-keepnames class org.shaded.apache.**
-keepnames interface com.fasterxml.jackson.** {
*;
}
-keep public class * extends com.android.partysearch.ChatApplication
-keepclassmembers class * extends com.android.partysearch.ChatApplication{
public <init>(android.content.Context);
}
-keep public class org.spongycastle.** {
<fields>;
<methods>;
}
-keep public class org.apache.** {
<fields>;
<methods>;
}
-ignorewarnings
-keepclasseswithmembernames class * {
native <methods>;
}
-keepclasseswithmembers class * {
public <init>(android.content.Context, android.util.AttributeSet);
}
-keepclasseswithmembers class * {
public <init>(android.content.Context, android.util.AttributeSet, int);
}
-keepclassmembers class * extends android.app.Activity {
public void *(android.view.View);
}
-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 * implements java.io.Serializable {
static final long serialVersionUID;
private static final java.io.ObjectStreamField[] serialPersistentFields;
private void writeObject(java.io.ObjectOutputStream);
private void readObject(java.io.ObjectInputStream);
java.lang.Object writeReplace();
java.lang.Object readResolve();
}
我用运行adblogcat命令检查崩溃报告。以下是我认为重要的报告片段:
E/AndroidRuntime(28630): Caused by: java.lang.RuntimeException: Something went wrong, please report to support@firebase.com
E/AndroidRuntime(28630): at com.firebase.client.core.h.a(Unknown Source)
E/AndroidRuntime(28630): at com.firebase.client.g.a(Unknown Source)
E/AndroidRuntime(28630): at com.partysearch.ChatApplication.onCreate(Unknown Source)
E/AndroidRuntime(28630): at android.app.Instrumentation.callApplicationOnCreate(Instrumentation.java:1024)
E/AndroidRuntime(28630): at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4694)
E/AndroidRuntime(28630): ... 10 more
E/AndroidRuntime(28630): Caused by: java.lang.NoSuchMethodException: <init> [class android.content.Context]
E/AndroidRuntime(28630): at java.lang.Class.getConstructorOrMethod(Class.java:423)
E/AndroidRuntime(28630): at java.lang.Class.getConstructor(Class.java:397)
E/AndroidRuntime(28630): ... 15 more
第二个片段:
W/System.err( 356): Caused by: libcore.io.ErrnoException: open failed: ENOENT (No such file or directory)
W/System.err( 356): at libcore.io.Posix.open(Native Method)
W/System.err( 356): at libcore.io.BlockGuardOs.open(BlockGuardOs.java:110)
W/System.err( 356): at libcore.io.IoBridge.open(IoBridge.java:393)
W/System.err( 356): ... 8 more
如果有人能帮助我,我将不胜感激并接受你的回答。
更新: 所以我将这些添加到我的 proguard 文件中
-keepattributes Signature
-keep class com.firebase.** { *; }
-keep class org.apache.** { *; }
-keepnames class javax.servlet.** { *; }
-keepnames class org.ietf.jgss.** { *; }
-dontwarn org.w3c.dom.**
-dontwarn org.joda.time.**
-dontwarn org.ietf.jgss.**
现在我在启用 Proguard 时遇到了与 Jackson 相关的错误。如果 Proguard 被禁用,该应用程序仍然可以工作。这是崩溃日志的片段:
E/AndroidRuntime( 6032): Caused by: com.shaded.fasterxml.jackson.databind.exc.UnrecognizedPropertyException: Unrecognized field "time" (class com.partysearch.Room), not marked as ignorable (5 known properties: , "note", "level", "userName", "console", "gametype"])
E/AndroidRuntime( 6032): at [Source: java.io.StringReader@42664098; line: 1, column: 51] (through reference chain: com.partysearch.Room["time"])
E/AndroidRuntime( 6032): at com.shaded.fasterxml.jackson.databind.DeserializationContext.reportUnknownProperty(DeserializationContext.java:555)
E/AndroidRuntime( 6032): at com.shaded.fasterxml.jackson.databind.deser.std.StdDeserializer.handleUnknownProperty(StdDeserializer.java:708)
E/AndroidRuntime( 6032): at com.shaded.fasterxml.jackson.databind.deser.BeanDeserializerBase.handleUnknownProperty(BeanDeserializerBase.java:1160)
E/AndroidRuntime( 6032): at com.shaded.fasterxml.jackson.databind.deser.BeanDeserializer.deserializeFromObject(BeanDeserializer.java:315)
E/AndroidRuntime( 6032): at com.shaded.fasterxml.jackson.databind.deser.BeanDeserializer.deserialize(BeanDeserializer.java:121)
E/AndroidRuntime( 6032): at com.shaded.fasterxml.jackson.databind.ObjectMapper._readMapAndClose(ObjectMapper.java:2888)
E/AndroidRuntime( 6032): at com.shaded.fasterxml.jackson.databind.ObjectMapper.readValue(ObjectMapper.java:2034)
E/AndroidRuntime( 6032): at com.firebase.client.DataSnapshot.getValue(DataSnapshot.java:184)
E/AndroidRuntime( 6032): ... 13 more
我敢猜测您的应用程序中的某些内容正在使用 Java 反射来实例化 class。
看来 class 这已经被 proguard 改名了。
您必须找出哪一个并为其添加例外规则。
您可以使用 proguard 创建的映射文件来确定在异常中使用了哪个 class 和方法。该文件位于 build/outputs/proguard/release/mapping.txt
我终于解决了。这是我忘记添加到我的 Proguard 文件中的内容。吸气剂和吸气剂。
-keep public class com.example.YourModelClassName {
public *** get*();
public void set*(***);
}
只需在您的 proguard-rules.pro 文件中添加 -keep class com.firebase.**{ *; }
。