android - Crashlytics 中的 Proguard 堆栈

标签 android proguard crashlytics

我无法阅读 Crashlytics 中的多个循环日志。

java.lang.NullPointerException
   at ahm.onClick(SourceFile:239)
   at android.view.View.performClick(View.java:4212)
   at android.view.View$PerformClick.run(View.java:17476)
   at android.os.Handler.handleCallback(Handler.java:800)
   at android.os.Handler.dispatchMessage(Handler.java:100)
   at android.os.Looper.loop(Looper.java:194)
   at android.app.ActivityThread.main(ActivityThread.java:5431)
   at java.lang.reflect.Method.invokeNative(Method.java)
   at java.lang.reflect.Method.invoke(Method.java:525)
   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:833)
   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:600)
   at dalvik.system.NativeStart.main(NativeStart.java)

java.lang.NullPointerException
   at com.app.mobile.RutaActivity.a(SourceFile:747)
   at ahh.run(SourceFile:1055)
   at java.lang.Thread.run(Thread.java:856)

在第一个日志中,我的应用包的名称从未被提及,所以我什至不知道去哪里寻找我的 NPE。

在第二个日志中,我有文件名 (RutaActivity),但是当我查看行号时,我看不到 NPE 错误的位置...

我该怎么办? 我怎样才能在第二个日志中看到方法名称而不是方法名称?

我的 Proguard 文件:

##---------------Begin: proguard configuration common for all Android apps ----------
-optimizationpasses 5
-dontskipnonpubliclibraryclassmembers
-dontpreverify
-dump class_files.txt
-printseeds seeds.txt
-printusage unused.txt
-printmapping mapping.txt

-optimizations !code/simplification/arithmetic,!field/*,!class/merging/*

-allowaccessmodification
-renamesourcefileattribute SourceFile
-keepattributes SourceFile,LineNumberTable, LocalVariableTable,LocalVariableTypeTable
-repackageclasses ''


-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
-dontnote com.android.vending.licensing.ILicensingService

-keep public class * extends android.view.View {
    public <init>(android.content.Context);
    public <init>(android.content.Context, android.util.AttributeSet);
    public <init>(android.content.Context, android.util.AttributeSet, int);
    public void set*(...);
}

# Explicitly preserve all serialization members. The Serializable interface
# is only a marker interface, so it wouldn't save them.
-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();
}


# Preserve all native method names and the names of their classes.
-keepclasseswithmembers class * {
    public <init>(android.content.Context, android.util.AttributeSet);
}
-keepclassmembers class * extends android.content.Context {
   public void *(android.view.View);
   public void *(android.view.MenuItem);
}

-keepclassmembers class * {
    @android.webkit.JavascriptInterface <methods>;
}


-keepclasseswithmembernames class * {
    public <init>(android.content.Context, android.util.AttributeSet);
}


-keepclasseswithmembernames class * {
    public <init>(android.content.Context, android.util.AttributeSet, int);
}


# Preserve static fields of inner classes of R classes that might be accessed
# through introspection.
-keepclassmembers class **.R$* {
  public static <fields>;
}


##---------------End: proguard configuration common for all Android apps ----------


##---------------Begin: proguard configuration for Gson  ----------
# Gson uses generic type information stored in a class file when working with fields. Proguard
# removes such information by default, so configure it to keep all of it.
-keepattributes Signature


# Gson specific classes
-keep class sun.misc.Unsafe { *; }

# Application classes that will be serialized/deserialized over Gson
-keep class com.google.gson.examples.android.model.** { *; }


##---------------End: proguard configuration for Gson  ----------

##---------------Begin proguard configuration for Google Maps --------------------

-keep class com.google.android.gms.** { *; }
-dontwarn com.google.android.gms.**

-keep class org.** { *; }
-keep class * extends java.util.ListResourceBundle {
    protected Object[][] getContents();
}

-keep public class com.google.android.gms.common.internal.safeparcel.SafeParcelable {
    public static final *** NULL;
}

-keepnames @com.google.android.gms.common.annotation.KeepName class *
-keepclassmembernames class * {
    @com.google.android.gms.common.annotation.KeepName *;
}


-renamesourcefileattribute SourceFile
-keepattributes SourceFile,LineNumberTable

##---------------End proguard configuration for Google Maps --------------------

##---------------Begin proguard configuration for my libs  -----------------------
-keep class com.todddavies.components.progressbar.** { *; }
-dontwarn com.todddavies.components.progressbar.**

-dontwarn org.apache.**

-keepclassmembers class * implements android.os.Parcelable {
    static ** CREATOR;
}

#Disable logging

-assumenosideeffects class android.util.Log {
    public static *** d(...);
    public static *** v(...);
    public static *** i(...);
}
-keep class com.app.mobile.vo.Captura { *; }
-keep class com.app.mobile.vo.Formulario { *; }
-keep class com.app.mobile.vo.Metrica { *; }
-keep class com.app.mobile.vo.Pdv { *; }
-keep class com.app.mobile.vo.Proyecto { *; }
-keep class com.app.mobile.vo.Producto { *; }
-keep class com.app.mobile.vo.Nota { *; }
-keep class com.app.mobile.vo.Encuesta { *; }
-keep class com.app.mobile.vo.Usuario { *; }
-keep class com.app.mobile.vo.BambooPerf { *; }
-keep class com.app.mobile.vo.SoftwareVersion { *; }

最佳答案

我联系了 Crashlytics 支持,我解决了问题!

他们让我检查 Crashlytics.log:

在 Linux/Windows 上: ~/.crashlytics/com.crashlytics.tools/crashlytics.log

在 Mac 上: ~/Library/Caches/com.crashlytics/com.crashlytics.tools/crashlytics.log

在这里我看到了:

Crashlytics detected deobfuscation, but did not find a mapping file at /Users/admin/AndroidstudioProjects/MyApp/build/outputs/mapping/release/mapping.txt

所以我刚刚改变

-printmapping mapping.txt

-printmapping build/outputs/mapping/release/mapping.txt

成功了!

谢谢你的帮助!

关于android - Crashlytics 中的 Proguard 堆栈,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30361621/

相关文章:

Android - 隐藏 API clientId 和 clientSecret 的最佳方式

android - 在 WebView 谷歌地图中获取当前位置

安卓;启动后服务自动启动 : FLAG_INCLUDE_STOPPED_PACKAGES not working

android - 如何在数据绑定(bind)的 xml 中有空格和特殊字符?

android - Flutter:将 Proguard 与 Gradle 7.0.4 结合使用

obfuscation - 使用 proguard 混淆后,使用 google guice 注入(inject)不再起作用

java - 有什么方法可以在不使用 ProGuard 优化的情况下删除日志记录调用?

android - java.lang.IllegalArgumentException : Comparison method violates its general contract?

ios - Firebase Crashlytics : missing OPTIONAL dSYMs

Android Crashlytics 发送不正确的行号