ProGuard
具体ProGuard是什么,他的定义、用途之类的我这里就不再做详细叙述了。
相信大家都经常在项目中用他来做混淆,其实ProGuard一共有四个功能,例如他可以检索到代码中没有没引用到的代码块并进行删除;可以对代码进行压缩和预校验等,感兴趣的可以自行查阅资料。
这里只是给大家提供一个ProGuard的常用模板,大家可以保留一份,需要用到的时候复制粘贴,再根据自己项目情况略做更改即可。
# 代码混淆压缩比,在0和7之间,默认为5,一般不需要改
-optimizationpasses 5
# 混淆时不使用大小写混合,混淆后的类名为小写
#windows用户添加 因为windows系统文件名不区分大小写当你的类名大于26个时 proGuard混淆时会以大小写混合的方式区分不同文件 此时会造成文件相互覆盖的现象 )
#mac 是基于Unix系统的 区分大小写 是不需要添加的
-dontusemixedcaseclassnames
# 指定不去忽略非公共的库的类
-dontskipnonpubliclibraryclasses
# 指定不去忽略非公共的库的类的成员
-dontskipnonpubliclibraryclassmembers
# 不做预校验,preverify是proguard的4个步骤之一
# Android不需要preverify,去掉这一步可加快混淆速度
-dontpreverify
# 有了verbose这句话,混淆后就会生成映射文件
# 包含有类名->混淆后类名的映射关系
# 然后使用printmapping指定映射文件的名称
-verbose
-printmapping proguardMapping.txt
# 指定混淆时采用的算法,后面的参数是一个过滤器
# 这个过滤器是谷歌推荐的算法,一般不改变
-optimizations !code/simplification/arithmetic,!field/*,!class/merging/*
# 保护代码中的Annotation不被混淆,这在JSON实体映射时非常重要,比如fastJson
-keepattributes *Annotation*
# 避免混淆泛型,这在JSON实体映射时非常重要,比如fastJson
-keepattributes Signature
#抛出异常时保留代码行号
-keepattributes SourceFile,LineNumberTable
# 保留所有的本地native方法不被混淆
-keepclasseswithmembernames class * {
native <methods>;
}
# 保留了继承自Activity、Application这些类的子类
# 因为这些子类,都有可能被外部调用
# 比如说,第一行就保证了所有Activity的子类不要被混淆
-keep public class * extends android.app.Activity
-keep public class * extends android.app.Application
-keep public class * extends android.app.Service
-keep public class * extends android.content.BroadcastReceiver
-keep public class * extends android.content.ContentProvider
-keep public class * extends android.app.backup.BackupAgentHelper
-keep public class * extends android.preference.Preference
-keep public class * extends android.view.View
-keep public class com.android.vending.licensing.ILicensingService
# 如果有引用android-support-v4.jar包,可以添加下面这行
-keep public class com.youngheart.app.ui.fragment.** {*;}
# 保留在Activity中的方法参数是view的方法,
# 从而我们在layout里面编写onClick就不会被影响
-keepclassmembers class * extends android.app.Activity {
public void *(android.view.View);
}
# 枚举类不能被混淆
-keepclassmembers enum * {
public static **[] values();
public static ** valueOf(java.lang.String);
}
# 保留自定义控件(继承自View)不被混淆
-keep public class * extends android.view.View {
*** get*();
void set*(***);
public <init>(android.content.Context);
public <init>(android.content.Context, android.util.AttributeSet);
public <init>(android.content.Context, android.util.AttributeSet, int);
}
# 保留Parcelable序列化的类不被混淆
-keep class * implements android.os.Parcelable {
public static final android.os.Parcelable$Creator *;
}
# 保留Serializable序列化的类不被混淆
-keepclassmembers class * implements java.io.Serializable {
static final long serialVersionUID;
private static final java.io.ObjectStreamField[] serialPersistentFields;
private void writeObject(java.io.ObjectOutputStream);
private void readObject(java.io.ObjectInputStream);
java.lang.Object writeReplace();
java.lang.Object readResolve();
}
# 对于R(资源)下的所有类及其方法,都不能被混淆
-keep class **.R$* {
*;
}
# 对于带有回调函数onXXEvent的,不能被混淆
-keepclassmembers class * {
void *(**On*Event);
}
# 对WebView的处理
-keepclassmembers class * extends android.webkit.webViewClient {
public void *(android.webkit.WebView, java.lang.String, android.graphics.Bitmap);
public boolean *(android.webkit.WebView, java.lang.String);
}
-keepclassmembers class * extends android.webkit.webViewClient {
public void *(android.webkit.webView, java.lang.String);
}
# 针对android-support-v4.jar的解决方案
-libraryjars libs/android-support-v4.jar
-dontwarn android.support.v4.**
-keep class android.support.v4.** { *; }
-keep interface android.support.v4.app.** { *; }
-keep public class * extends android.support.v4.**
-keep public class * extends android.app.Fragment
# 对alipay的混淆处理
-libraryjars libs/alipaysdk.jar
-dontwarn com.alipay.android.app.**
-keep public class com.alipay.** { *; }
#以下部分需要根据项目具体内容进行添加
# 保留实体类和成员不被混淆
#(用实体类的具体包名替换xxx)
-keep public class xxx.** {
public void set*(***);
public *** get*();
public *** is*();
}
# 保留内嵌类不被混淆
#(用包含内部类的类名绝对路径替换xxx) $为分隔符 后边的为内部类的名称
-keep class xxx$* { *; }
# 保留JS方法不被混淆
#用含有js回调方法的类名替换xxx 用xxx类中的js回调内部类替换yyy 具体可以检索项目中的注解@JavascriptInterface的使用位置
-keepclassmembers class xxx$yyy {
<methods>;
}
#保留代码中所有反射用到的类不会被混淆
#-keep class 具体类名
#以上部分需要根据项目具体内容进行添加
同时可以使用@Keep注解对你需要保留的类,属性,方法等进行保护,在今年的Google I/O大会上发布的Android Studio 2.2新增功能中,可以对项目或者某个文件中的注解进行分析,那些地方使用了哪些注解,管理起来还是很方便的(虽然目前的preview版本中还没有该功能,但也不会太远了)
大家根据自己项目具体情况对模板进行修改,使用各种第三方的请自行查阅开发文档,根据官方要求添加。