about 混淆

proguard-android.txt内容:
这是一个ProGuard的配置文件。但是这份文件已经不再维护,而且android gradle plugin2.2之后也不会再使用这份文件。取而代之的是,gradle 插件会在每次build的时候生成默认的rule文件并且存储在构建目录。
代码优化在默认情况下是关闭的。因为Dex不喜欢代码经过ProGuard优化和预验证步骤后运行(并执行一些这些优化本身)。

注意,如果你想启用优化,你不能只在配置文件中使用optimization标志。相反,您需要在project.properties中指向“proguard-android-optimize.txt“文件,而不是这个文件。

以下内容来自转载

#混淆时不生成大小写混合的类名
-dontusemixedcaseclassnames
#不忽略非公共的类库
-dontskipnonpubliclibraryclasses
#混淆过程中打印详细信息
-verbose

#关闭优化
-dontoptimize
#不预校验
-dontpreverify

# Annotation注释不能混淆
-keepattributes *Annotation*
#对于NDK开发 本地的native方法不能被混淆
-keepclasseswithmembernames class * {
    native ;
}
#保持View的子类里面的set、get方法不被混淆(*代替任意字符)
-keepclassmembers public class * extends android.view.View {
   void set*(***);
   *** get*();
}

#保持Activity子类里面的参数类型为View的方法不被混淆,如被XML里面应用的onClick方法
# We want to keep methods in Activity that could be used in the XML attribute onClick
-keepclassmembers class * extends android.app.Activity {
   public void *(android.view.View);
}

#保持枚举类型values()、以及valueOf(java.lang.String)成员不被混淆
-keepclassmembers enum * {
    public static **[] values();
    public static ** valueOf(java.lang.String);
}

#保持实现Parcelable接口的类里面的Creator成员不被混淆
-keepclassmembers class * implements android.os.Parcelable {
  public static final android.os.Parcelable$Creator CREATOR;
}

#保持R类静态成员不被混淆
-keepclassmembers class **.R$* {
    public static ;
}

#不警告support包中不使用的引用
-dontwarn android.support.**
-keep class android.support.annotation.Keep
-keep @android.support.annotation.Keep class * {*;}
#保持使用了Keep注解的方法以及类不被混淆
-keepclasseswithmembers class * {
    @android.support.annotation.Keep ;
}
#保持使用了Keep注解的成员域以及类不被混淆
-keepclasseswithmembers class * {
    @android.support.annotation.Keep ;
}
-keepclasseswithmembers class * {
    @android.support.annotation.Keep (...);
}

作者:一件小毛衣
链接:https://www.jianshu.com/p/86ee6ef970ef
來源:
著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

你可能感兴趣的:(about 混淆)