要启用代码混淆,在build.gradle文件中的最简配置可能是这样的:
buildTypes {
release {
minifyEnabled true
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
}
}
其中,「proguardFiles」属性用于配置「混淆规则文件」,而作为默认文件之一的「proguard-rules.pro」 ,则是在我们创建新模块时自动添加的,通常不包含任何规则,需要我们自己添加。
我们日常添加和维护混淆规则,通常也都是直接在 proguard-rules.pro 文件上进行的。
这样做的弊端就是:
- 随着引入模块的增加,日渐膨胀的 proguard-rules.pro 文件难以维护
- 各种规则胡填海塞,当出现因代码混淆导致的问题时,难以定位到具体的混淆规则并修复
解决这个问题的关键就是 proguardFiles 属性,该属性允许我们添加多个混淆规则文件,以此添加额外的混淆规则。
我们可以遵循单一职责原则,按照混淆规则大体上的分类,将混淆规则文件拆分为以下三个:
- 通用混淆规则文件(proguard-common.pro)
#-----------通用基本配置的混淆规则---------------
# 指定不去忽略非公共的库的类
-dontskipnonpubliclibraryclasses
# 指定不去忽略非公共的库的类的成员
-dontskipnonpubliclibraryclassmembers
# 保留了继承自Activity、Application、Fragment这些类的子类
-keep public class * extends android.app.Fragment
-keep public class * extends android.app.Activity
-keep public class * extends android.app.Application
-keep public class * extends android.app.Service
以下省略...
- 项目自身混淆规则文件(proguard-rules.pro)
#-----------针对本项目的混淆规则--------------
# 保留指定包以及所含子包下的类名和类成员(变量和方法)不被混淆
-keep class com.xxx.database.constants.**{*;}
-keep class com.xxx.database.beanextra.**{*;}
-keep class com.arthenica.mobileffmpeg.**{*;}
# 保留指定类名和类成员(变量和方法)不被混淆
-keep class com.xxx.comp.dynamic.manager.AVUManager{*;}
-keep interface com.xxx.remote.util.MessageEntityConverter{*;}
以下省略...
- 第三方SDK规则文件(proguard-third.pro)
#-----------第三方类库的混淆规则--------------
# OkHttp
-dontwarn com.squareup.okhttp3.**
-keep class com.squareup.okhttp3.** { *;}
-dontwarn okio.**
# Glide
-keep public class * implements com.bumptech.glide.module.GlideModule
-keep public enum com.bumptech.glide.load.resource.bitmap.ImageHeaderParser$** {
**[] $VALUES;
public *;
}
-keep class com.bumptech.**{*;}
以下省略...
随后在 proguardFiles 属性 中追加配置其余2个混淆规则文件即可:
buildTypes {
release {
minifyEnabled tue
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro', 'proguard-common.pro', 'proguard-third.pro'
}
}
通用混淆规则基本不变,第三方SDK混淆规则只需要在引入新的类库时添加,我们平时主要维护项目自身混淆规则文件就可以了。
而当出现因代码混淆导致的问题时,我们就可以直接排查项目项目自身混淆规则文件,快速定位到具体的混淆规则并修复了。
Hi,我是椎锋陷陈,现已更名为「IM开发者」,诚如我的简介所言:
基于移动端,汇集「即时通讯」、「WebRTC」、「移动开发」等内容,致力于打造一个服务于即时通讯技术爱好者的技术分享平台。
以后会致力于推送这三方面的内容,感谢断更数月到现在依旧关注的小伙伴的陪伴。
本次内容是我的一个新的尝试,由于构建一篇系统的干货文章需要的写作周期很长,而现在基本每天只有碎片化的业余时间,但又想保持每天的一个写作输出,因此采用了类似「每日小技巧」这种形式,希望能帮助你快速实践到日常开发中,提高开发效率。
当然,系统的干货文章也不会落下,会积极根据日常推送的反馈,收集你们感兴趣的内容,集合成一片更系统完整的文章后输出。
如果对你有帮助,请别忘记点赞和关注噢,谢谢~