Android 混淆去掉log无效 assumenosideeffects 不起作用

1、app/build下配置如下

    buildTypes {
        debug {
            minifyEnabled true
            buildConfigField("boolean","LOG_DEBUG","true")
        }
        release {
            minifyEnabled true
            proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
            buildConfigField("boolean","LOG_DEBUG","false")
        }
    }

proguard-rules.pro下配置如下:

-assumenosideeffects class android.util.Log {
    public static *** d(...);
    public static *** e(...);
    public static *** i(...);
    public static *** v(...);
    public static *** println(...);
    public static *** w(...);
    public static *** wtf(...);
}
-assumenosideeffects class *****(包名).DebugLog {
    public static *** d(...);
    public static *** e(...);
    public static *** i(...);
    public static *** v(...);
    public static *** println(...);
    public static *** w(...);
    public static *** wtf(...);
}
-assumenosideeffects class java.io.PrintStream {
  public *** println(...);
  public *** print(...);
}

最后发现,在自己写的demo里明明是可以实现混淆log的,但是放到实际项目中确不能混淆,网上查资料,发现:

1、需要使用的是proguard-android-optimize.txt这个文件,不是Android Studio默认使用的proguard-android.txt
2、不能有“-dontoptimize”这句话 一定要将其注释掉;

检查后发现也没有错误,网上查阅了几乎所有文章也没有得出结论,最后在一次次试错中发现,如果导入的jar包或者aar文件中存在禁止优化“-dontoptimize”的话,也会导致整个工程不能优化log,所以要将aar包中的“-dontoptimize”也去掉才行,特此记录一下,如果对你有帮助,给点个赞呗0.0

你可能感兴趣的:(Android,异常处理)