这里是被混淆的代码错误
Caused by: java.lang.NullPointerException
at net.demo.zx.be.u(Unknown Source)
at net.demo.zx.at.v(Unknown Source)
at net.demo.zx.at.d(Unknown Source)
at net.demo.zx.av.onReceive(Unknown Source)
还原之后是这个样子的
Caused by: java.lang.NullPointerException
at net.demo.zx.UtilTelephony.boolean is800MhzNetwork()(Unknown Source)
at net.demo.zx.ServiceDetectLte.void checkAndAlertUserIf800MhzConnected()(Unknown Source)
at net.demo.zx.ServiceDetectLte.void startLocalBroadcastReceiver()(Unknown Source)
at net.demo.zx.ServiceDetectLte$2.void onReceive(android.content.Context,android.content.Intent)(Unknown Source)
mapping.txt的位置在app/build/outputs/mapping/mapping.txt
切换到 proguard 项目中去 地址位于 SDK下 sdk/tools/proguard/bin
将mapping.txt 复制到此目录下
创建一个新文件 log.txt 将错误信息复制进去
打开控制器进入到Proguard bin目录下 使用命令
retrace mapping.txt log.txt
但是还原后还会有Unknown Source
这是因为Proguard在混淆代码的 时候会做一些优化,比如行号、源文件这些信息其实VM是不需要的所以优化的时候会删除这些信息,导致SDK拿到的堆栈是没有这些信息的。
解决这个问题需要在 Proguard的配置文件中添加
-keepattributes SourceFile,LineNumberTable