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