使用 Proguard 时的未知来源

Posted

技术标签:

【中文标题】使用 Proguard 时的未知来源【英文标题】:Unknown Source when I use Proguard 【发布时间】:2015-07-14 03:03:35 【问题描述】:

如果我使用 Proguard(minifyEnabled trueshrinkResources true),我的崩溃报告有点用处

这是 Proguard 的报告:

java.lang.NullPointerException: Attempt to invoke virtual method 'void android.widget.ProgressBar.setVisibility(int)' on a null object reference
    at xx.xxxx.xxx.xxxxx.xxxxxx.restoreViewAfterLoading(Unknown Source)
    at xx.xxxx.xxx.xxxxx.xxxxxx.newInstance(Unknown Source)
                                                     onCreateView
                                                     onViewCreated
                                                     access$000
    at xx.xxxx.xxx.xxxxx.xxxxxx$1.success(Unknown Source)
    at xx.xxxx.xxx.xxxxx.xxxxxx$1.success(Unknown Source)
    at retrofit.CallbackRunnable$1.run(Unknown Source)
    at android.os.Handler.handleCallback(Handler.java:739)
    at android.os.Handler.dispatchMessage(Handler.java:95)
    at android.os.Looper.loop(Looper.java:135)
    at android.app.ActivityThread.main(ActivityThread.java:5254)
    at java.lang.reflect.Method.invoke(Native Method)
    at java.lang.reflect.Method.invoke(Method.java:372)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)

这是没有 Proguard 的正常报告:

java.lang.NullPointerException: Attempt to invoke virtual method 'void android.widget.ProgressBar.setVisibility(int)' on a null object reference
    at xx.xxxx.xxx.xxxxx.xxxxxx.restoreViewAfterLoading(xxxxxx.java:123)
    at xx.xxxx.xxx.xxxxx.xxxxxx.access$000(xxxxxx.java:26)
    at xx.xxxx.xxx.xxxxx.xxxxxx$1.success(xxxxxx.java:96)
    at xx.xxxx.xxx.xxxxx.xxxxxx$1.success(xxxxxx.java:92)
    at retrofit.CallbackRunnable$1.run(CallbackRunnable.java:45)
    at android.os.Handler.handleCallback(Handler.java:739)
    at android.os.Handler.dispatchMessage(Handler.java:95)
    at android.os.Looper.loop(Looper.java:135)
    at android.app.ActivityThread.main(ActivityThread.java:5254)
    at java.lang.reflect.Method.invoke(Native Method)
    at java.lang.reflect.Method.invoke(Method.java:372)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)

我可以用 Proguard 获取行号吗?

【问题讨论】:

【参考方案1】:

看起来您在名为restoreViewAfterLoading 的方法中的某个文件中有一个NPE,其中setVisibility 在某个文件的第123 行周围的ProgressBar(为空)上调用。这一切都发生在改造回调上。因此,我首先要解决的问题是检查 null 以防用户完成此活动/片段。

要获得更好的行号,请将以下内容添加到您的 proguard 配置中

# Preserve annotations, line numbers, and source file names
-keepattributes *Annotation*,SourceFile,LineNumberTable

这将保留混淆堆栈跟踪中的行号。

HTH

【讨论】:

这不是对安全的妥协吗?

以上是关于使用 Proguard 时的未知来源的主要内容,如果未能解决你的问题,请参考以下文章

使用 ProGuard 混淆私有字段

DexGuard/Proguard 混淆注释值

为啥 proguard 不混淆方法体?

使 Proguard 完全忽略包

新(空白)项目上的尴尬 Proguard 错误

如何准确解码 ProGuard 的混淆代码?