grade 配置
使用 AndroidStudio , 在 build.grade 的配置文件中增加如下配置即可:
- buildTypes {
- release {
- debuggable false
- minifyEnabled true // 是否启动混淆 ture: 打开 false: 关闭
- proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
- }
找到 proguard-rules.pro 文件增加混淆方法
只要在工程应用目录的 gradle 文件中设置 minifyEnabled:true 即可. 然后我们就可以到 proguard-rules.pro 文件中加入我们的混淆规则了, 这里展示一些常用的混淆: 自定义不混淆的需要在自定义后面增加
- #############################################
- #
- # 对于一些基本指令的添加
- #
- #############################################
- # 代码混淆压缩比, 在 0~7 之间, 默认为 5, 一般不做修改
- -optimizationpasses 5
- # 混合时不使用大小写混合, 混合后的类名为小写
- -dontusemixedcaseclassnames
- # 指定不去忽略非公共库的类
- -dontskipnonpubliclibraryclasses
- # 这句话能够使我们的项目混淆后产生映射文件
- # 包含有类名 ->混淆后类名的映射关系
- -verbose
- # 指定不去忽略非公共库的类成员
- -dontskipnonpubliclibraryclassmembers
- # 不做预校验, preverify 是 proguard 的四个步骤之一, Android 不需要 preverify, 去掉这一步能够加快混淆速度.
- -dontpreverify
- # 保留 Annotation 不混淆
- -keepattributes *Annotation*,InnerClasses
- # 避免混淆泛型
- -keepattributes Signature
- # 抛出异常时保留代码行号
- -keepattributes SourceFile,LineNumberTable
- # 指定混淆是采用的算法, 后面的参数是一个过滤器
- # 这个过滤器是谷歌推荐的算法, 一般不做更改
- -optimizations !code/simplification/cast,!field/*,!class/merging/*
- #############################################
- #
- # Android 开发中一些需要保留的公共部分
- #
- #############################################
- # 保留我们使用的四大组件, 自定义的 Application 等等这些类不被混淆
- # 因为这些子类都有可能被外部调用
- -keep public class * extends Android.App.Activity
- -keep public class * extends Android.App.Appliction
- -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
- # 保留 support 下的所有类及其内部类
- -keep class Android.support.** {*;}
- # 保留继承的
- -keep public class * extends Android.support.v4.**
- -keep public class * extends Android.support.v7.**
- -keep public class * extends Android.support.annotation.**
- # 保留 R 下面的资源
- -keep class **.R$* {*;}
- # 保留本地 native 方法不被混淆
- -keepclasseswithmembernames class * {
- native <methods>;
- }
- # 保留在 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;
- !static !transient <fields>;
- !private <fields>;
- !private <methods>;
- private void writeObject(java.io.ObjectOutputStream);
- private void readObject(java.io.ObjectInputStream);
- java.lang.Object writeReplace();
- java.lang.Object readResolve();
- }
- # 对于带有回调函数的 onXXEvent,**On*Listener 的, 不能被混淆
- -keepclassmembers class * {
- void *(**On*Event);
- void *(**On*Listener);
- }
- # webView 处理, 项目中没有使用到 webView 忽略即可
- -keepclassmembers class fqcn.of.JavaScript.interface.for.webview {
- public *;
- }
- -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, jav.lang.String);
- }
- #############################################
- #
- # 自定义不混淆区域
- #
- #############################################
混淆 ProGuard 常用语法
// 不混淆某个类
-keep public class 所在包名. 类名 { *; }
// 不混淆某个类的子类
-keep public class * extends 所在包名. 类名 { *; }
- // 不混淆所有类名中包含了 "model" 的类及其成员
- -keep public class **.*model*.** {
- *;
- }
- // 不混淆某个接口的实现
-keep class * implements 所在包名. 接口类名 { *; }
// 不混淆某个类的构造方法
-keepclassmembers class 所在包名. 类名 {
- public <init>();
- }
- // 不混淆某个类的特定的方法
-keepclassmembers class 所在包名. 类名 {
- public void test(java.lang.String);
- }
- // 不混淆某个类的内部类
-keep class 所在包名. 类名 $* {
- *;
- }
- // 两个常用的混淆命令, 注意:
- // 一颗星表示只是保持该包下的类名, 而子包下的类名还是会被混淆;
- // 两颗星表示把本包和所含子包下的类名都保持;
- -keep class com.suchengkeji.Android.ui.**
- -keep class com.suchengkeji.Android.ui.*
- // 用以上方法保持类后, 你会发现类名虽然未混淆, 但里面的具体方法和变量命名还是变了,
- // 如果既想保持类名, 又想保持里面的内容不被混淆, 我们就需要以下方法了
- // 不混淆某个包所有的类
- -keep class com.suchengkeji.Android.bean.** { *; }
从混淆后的目录看到, 代码明显晕未混淆的不同, 属性方法基本都用啊, b,c... 表示了, 更不容易看懂代码结果和方法, 这就减少了源码的外泄等
来源: http://www.jianshu.com/p/d299487bb062