android 資源混淆

方案選擇:

1.微信混淆方案(AndResGuard)
2.美團(tuán)混淆方案

區(qū)別:

微信的方案是通過(guò)修改aapt在處理資源文件相關(guān)的源碼達(dá)到資源文件的替換;而美團(tuán)主要通過(guò)直接修改resources.arsc文件達(dá)到資源文件混淆的目的。微信從aapt的原理上著手,而美團(tuán)只是在已有的方案上優(yōu)化,相比之下,微信的混淆更徹底。

什么是AndResGuard
??AndResGuard是一個(gè)縮小APK大小的工具,它的原理類(lèi)似Java Proguard,但是只針對(duì)資源。它會(huì)將原本冗長(zhǎng)的資源路徑變短,例如將res/drawable/wechat變?yōu)閞/d/a。

在以往的開(kāi)發(fā)中,我們通常只混淆了代碼,資源文件卻暴露在他人面前,res文件夾下所有文件名的可讀性過(guò)強(qiáng)。

微信的開(kāi)源庫(kù)AndResGuard正好解決這種問(wèn)題,對(duì)資源進(jìn)行混淆,保護(hù)res資源文件的可讀性,同時(shí),可以減少APP的大小

AndResGuard的配置

  1. 項(xiàng)目根目錄下build.gradle中,添加插件的依賴(lài):
 dependencies {
        classpath 'com.tencent.mm:AndResGuard-gradle-plugin:1.2.10'
    }
    
  1. app模塊中build.gradle中,添加相關(guān)配置
apply plugin: 'AndResGuard'

andResGuard {
    // mappingFile = file("./resource_mapping.txt")
    mappingFile = null
    use7zip = false
    useSign = true
    // It will keep the origin path of your resources when it's true
    keepRoot = false
    // If set, name column in arsc those need to proguard will be kept to this value
    fixedResName = "arg"
    // It will merge the duplicated resources, but don't rely on this feature too much.
    // it's always better to remove duplicated resource from repo
    mergeDuplicatedRes = true
    whiteList = [
            // your icon
            "R.drawable.ic_launcher*",
            "R.anim.umeng*",
            "R.string.umeng*",
    ]
    compressFilePattern = [
            "*.png",
            "*.jpg",
            "*.jpeg",
            "*.gif",
            "*.webp",
    ]
    sevenzip {
        artifact = 'com.tencent.mm:SevenZip:1.2.20'
        //path = "/usr/local/bin/7za"
    }

    /**
     * Optional: if finalApkBackupPath is null, AndResGuard will overwrite final apk
     * to the path which assemble[Task] write to
     **/
    // finalApkBackupPath = "${project.rootDir}/final.apk"

    /**
     * Optional: Specifies the name of the message digest algorithm to user when digesting the entries of JAR file
     * Only works in V1signing, default value is "SHA-1"
     **/
    // digestalg = "SHA-256"
}

其中whiteList(白名單)中指定不需要進(jìn)行混淆的資源路徑規(guī)則,主要是針對(duì)第三方SDK,因?yàn)橛行㏒DK的代碼中通過(guò)getIdentifier()的方式引用到對(duì)應(yīng)的資源文件,如果對(duì)其進(jìn)行混淆,會(huì)導(dǎo)致找不到對(duì)應(yīng)資源文件,出現(xiàn)crash。

androId尋找資源方式:

resources.arsc結(jié)構(gòu):


image.png
  1. 通過(guò)包名(package name),類(lèi)型(type,如dimen,drawable,color,string等),資源名(name)在表resources.arsc中查找對(duì)應(yīng)資源的Id.

  2. 然后通過(guò)getResources().getDrawable(resourceId)或者getResources().getDimensionPixelSize(resourceId)等方法拿到對(duì)應(yīng)的資源.

而一旦進(jìn)行資源混淆后,資源名發(fā)生變化,會(huì)導(dǎo)致找不到資源id。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 混淆是 Android 打包過(guò)程中最重要的流程之一,基本上所有 app 都應(yīng)該開(kāi)啟混淆,增加app的安全性。混淆其...
    shenhuniurou閱讀 1,655評(píng)論 0 2
  • 關(guān)于AndResGuard AndResGuard是一個(gè)幫助你縮小APK大小的工具,他的原理類(lèi)似Java Prog...
    料峭寒閱讀 8,356評(píng)論 3 17
  • 什么是AndResGuard ??AndResGuard是一個(gè)縮小APK大小的工具,它的原理類(lèi)似Java Prog...
    王培921223閱讀 576評(píng)論 0 0
  • 久違的晴天,家長(zhǎng)會(huì)。 家長(zhǎng)大會(huì)開(kāi)好到教室時(shí),離放學(xué)已經(jīng)沒(méi)多少時(shí)間了。班主任說(shuō)已經(jīng)安排了三個(gè)家長(zhǎng)分享經(jīng)驗(yàn)。 放學(xué)鈴聲...
    飄雪兒5閱讀 7,822評(píng)論 16 22
  • 今天感恩節(jié)哎,感謝一直在我身邊的親朋好友。感恩相遇!感恩不離不棄。 中午開(kāi)了第一次的黨會(huì),身份的轉(zhuǎn)變要...
    余生動(dòng)聽(tīng)閱讀 10,857評(píng)論 0 11

友情鏈接更多精彩內(nèi)容