AndroidI每日小技巧I如何更好地维护代码混淆规则文件(Proguard)?

封面图

要启用代码混淆,在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

# 保留了继承自ActivityApplicationFragment这些类的子类
-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」、「移动开发」等内容,致力于打造一个服务于即时通讯技术爱好者的技术分享平台。

以后会致力于推送这三方面的内容,感谢断更数月到现在依旧关注的小伙伴的陪伴。

本次内容是我的一个新的尝试,由于构建一篇系统的干货文章需要的写作周期很长,而现在基本每天只有碎片化的业余时间,但又想保持每天的一个写作输出,因此采用了类似「每日小技巧」这种形式,希望能帮助你快速实践到日常开发中,提高开发效率。

当然,系统的干货文章也不会落下,会积极根据日常推送的反馈,收集你们感兴趣的内容,集合成一片更系统完整的文章后输出,欢迎持续关注。

猜你喜欢

转载自blog.csdn.net/Alfred_C/article/details/121048584
今日推荐