1 基础知识
(1)代码混淆(Obfuscated code)亦称花指令,是将计算机程序的代码,转换成一种功能上等价,但是难于阅读和理解的形式的行为。
(2)为什么要加代码混淆?
--------------------不想开源应用,为了加大反编译的成本,但是并不能彻底防止反编译
(3)开启混淆
release {
minifyEnabled true // 是否启动混淆 ture:打开 false:关闭
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
(4)proguard-rules.pro文件的作用
只要在工程应用目录的gradle文件中设置minifyEnabled:true即可。然后我们就可以到proguard-rules.pro文件中加入我们的混淆规则了;
(5)proguard是什么
Proguard是一个集文件压缩,优化,混淆和校验等功能的工具;
它检测并删除无用的类,变量,方法和属性;
它优化字节码并删除无用的指令;
它通过将类名,变量名和方法名重命名为无意义的名称实现混淆效果;
最后它还校验处理后的代码;
2 混淆的常见配置
2.1 Proguard关键字
(1)保留某个包下面的类以及子包
-keep public class com.droidyue.com.widget.**
(2)保留所有类中使用otto的public方法
# Otto
-keepclassmembers class ** {
@com.squareup.otto.Subscribe public *;
@com.squareup.otto.Produce public *;
}
(3)保留Contants类的BOOK_NAME属性
-keepclassmembers class com.example.admin.proguardsample.Constants {
public static java.lang.String BOOK_NAME;
}
(4)dontwarn
引入的library可能存在一些无法找到的引用和其他问题,在build时可能会发出警告,如果我们不进行处理,通常会导致build中止。因此为了保证build继续,我们需要使用dontwarn处理这些我们无法解决的library的警告
#比如关闭Twitter sdk的警告,我们可以这样做
-dontwarn com.twitter.sdk.**
2.2 Proguard通配符
2.3 基本规则
// 不混淆某个类
-keep public class name.huihui.example.Test { *; }
// 不混淆某个类的子类
-keep public class * extends name.huihui.example.Test { *; }
// 不混淆所有类名中包含了“model”的类及其成员
-keep public class **.*model*.** {*;}
// 不混淆某个接口的实现
-keep class * implements name.huihui.example.TestInterface { *; }
// 不混淆某个类的构造方法
-keepclassmembers class name.huihui.example.Test {
public <init>();
}
// 不混淆某个类的特定的方法
-keepclassmembers class name.huihui.example.Test {
public void test(java.lang.String);
}
// 不混淆某个类的内部类
-keep class name.huihui.example.Test$* {
*;
}
// 两个常用的混淆命令,注意:
// 一颗星表示只是保持该包下的类名,而子包下的类名还是会被混淆;
// 两颗星表示把本包和所含子包下的类名都保持;
-keep class com.suchengkeji.android.ui.**
-keep class com.suchengkeji.android.ui.*
/