Fabric,Crashylitics stacktraces没有反混淆。 Android的

时间:2017-04-17 07:13:27

标签: android crashlytics google-fabric

所以Fabric并没有完全对任何堆栈进行反混淆处理...... 它确实部分地这样做了,我注意到它将一些随机的未知方法附加到堆栈跟踪上,这些方法与上下文中的代码无关。

Fatal Exception: java.lang.NullPointerException: Attempt to invoke interface method 'android.content.Context in.ulink.agrostar.agroex.b.a.j.e()' on a null object reference
   at in.ulink.agrostar.agroex.presenter.HomePresenter.fetchLeadsFromApi(method 'onItemClicked':344)
   at in.ulink.agrostar.agroex.presenter.HomePresenter.syncOfflineLeadsAdded(method 'onItemClicked')
   at in.ulink.agrostar.agroex.presenter.HomePresenter$3.onPostExecute(method 'onItemClicked':554)
   at in.ulink.agrostar.agroex.presenter.HomePresenter$3.onPostExecute(method 'onItemClicked':540)
   at android.os.AsyncTask.finish(AsyncTask.java:651)
   at android.os.AsyncTask.access$500(AsyncTask.java:180)
   at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:668)
   at android.os.Handler.dispatchMessage(Handler.java:102)
   at android.os.Looper.loop(Looper.java:148)
   at android.app.ActivityThread.main(ActivityThread.java:5417)
   at java.lang.reflect.Method.invoke(Method.java)
   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)

这就是我的ProGuard映射文件中的内容

#FOR CRASHLYTICS 
-keepattributes *Annotation*
-keepattributes SourceFile,LineNumberTable

有人可以分享他们所做的事情,以便Crashlytics(Fabric)在没有ProGuard的调试模式下运行时提供精确的堆栈跟踪。

1 个答案:

答案 0 :(得分:3)

Mike来自Fabric。

目前,我们无法对消息中的消息部分进行反模糊处理,但您的Proguard配置需要进行一些更改。我补充说:

-keep public class * extends java.lang.Exception

另外,如果存在,请将其删除:

-printmapping mapping.txt

我们不会向使用映射文件时不存在或找不到的堆栈跟踪添加任何内容。