Gradle實戰:Android多渠道打包方案彙總

来源:http://www.cnblogs.com/meishan/archive/2016/09/24/5903502.html
-Advertisement-
Play Games

查看原文:http://blog.csdn.net/u010818425/article/details/52319382 Gradle實戰系列文章: 《Gradle基本知識點與常用配置》 《Gradle實戰:不同編譯類型的包同設備共存》 《Gradle實戰:發佈aar包到maven倉庫》 《Gra ...


查看原文:http://blog.csdn.net/u010818425/article/details/52319382

Gradle實戰系列文章: 
《Gradle基本知識點與常用配置》 
《Gradle實戰:不同編譯類型的包同設備共存》 
《Gradle實戰:發佈aar包到maven倉庫》 
《Gradle實戰:執行sql操作hive資料庫》


本文將延續之前幾篇博客的風格,先從基本概念入手,這有助於我們對後文的理解; 在後續的代碼中如果忘了某個概念的具體意義,可以回顧頭來重新查看概念的介紹。

文中先詳細介紹了普通批量打包方案的實現原理,後介紹了美團批量打包的基本實現原理,並引用了幾篇實現方案供大家參考


一、基本概念介紹

1. package

  • AndroidManifest文件中的包名

    <manifest xmlns:android="http://schemas.android.com/apk/res/android"
        package="com.company.appname"
        android:versionCode="1"
        android:versionName="1.0" >
    

    包名有兩個作用: 
    一是設備上應用程式的唯一標識,也是在應用市場上的唯一標識; 
    二是被用來命名你的資源類的包(以及解析任何相關的Activity的類名),如com.company.appname.R

2. PlaceHolder

  • AndroidManifest文件中的變數表示,通過${PlaceHolder}表示PlaceHolder是可以被賦值的變數,如友盟統計中的渠道:

    <meta-data
        android:name="UMENG_CHANNEL"
        android:value="${UMENG_CHANNEL_VALUE}">
    </meta-data>
    

3. applicationId

  • 對應於AndroidManifest中的package

    android {
        defaultConfig {
            applicationId "com.company.appname"
        }
    }
    

4. buildTypes

  • 用於生成不同編譯類型的包,如debug和release包

    android{
        buildTypes {
            debug {
                ...
            }
            release {
                ...
            }
        }
    }
    

    debug和release是gradle預設自帶的兩個build type,在工程自動生成的BuildConfig中,其區別如下:

    // release版本生成的BuildConfig特性信息
    public final class BuildConfig {
        public static final boolean DEBUG = false;
        public static final String BUILD_TYPE = "release";
    }
    
    // debug版本生成的BuildConfig特性信息
    public final class BuildConfig {
        public static final boolean DEBUG = true;
        public static final String BUILD_TYPE = "debug";
    }
    
  • 自定義不同的build type,如

    android{
        buildTypes {
            debug {
                ...
            }
            release {
                ...
            }
            beta {
                ...
            }
        }
    }
    

5. productFlavors

  • 用於生成不同渠道的包

    android {  
        productFlavors {
            xiaomi {}
            baidu {}
            wandoujia {}
            _360 {}        // 或“"360"{}”,數字需下劃線開頭或加上雙引號
        }
    }
    

    執行./gradlew assembleRelease,將會打出所有渠道的release包; 
    執行./gradlew assembleWandoujia,將會打出豌豆莢渠道的release和debug版的包; 
    執行./gradlew assembleWandoujiaRelease將生成豌豆莢的release包。

    因此,可以結合buildType和productFlavor生成不同的Build Variants,即類型與渠道不同的組合

6. signingConfigs

  • 簽名配置,release編譯類型的配置如:

    release {
        storeFile file("../yourapp.keystore") //簽名證書文件
        storePassword "your password"         //簽名證書密碼
        keyAlias "your alias"                 //別名
        keyPassword "your password"           //別名密碼
    }
    

    當然,簽名信息可以通過讀配置文件(見上一篇文章)和配置文件ignore的形式來進行隱藏,本文不作詳述。

7. META-INF文件

  • 用於存儲簽名的一些相關信息,在META-INF目錄內添加空文件,應用無需重新簽名。

二、多渠道打包配置

1. 一般打包方案

    //生成打包時間
    def releaseTime() {
        return new Date().format("yyyy-MM-dd", TimeZone.getTimeZone("UTC"))
    }

    android {
        compileSdkVersion 23
        buildToolsVersion "23.0.3"

        defaultConfig {
            applicationId "com.company.appname"
            minSdkVersion 15
            targetSdkVersion 23
            versionCode 1
            versionName "1.0"

            //預設渠道為官網
            manifestPlaceholders = [UMENG_CHANNEL_VALUE: "official"]
        }

        lintOptions {
            checkReleaseBuilds false
            abortOnError false
        }

        //配置編譯的jdk版本
        compileOptions {
            sourceCompatibility org.gradle.api.JavaVersion.VERSION_1_7
            targetCompatibility org.gradle.api.JavaVersion.VERSION_1_7
        }

        //簽名配置
        signingConfigs {
            debug {
                // No debug config
                storeFile file("${rootDir}/keystores/xqsg_debug.jks") //debug證書
            }

            release {
                storeFile file("${rootDir}/keystores/xqsg.jks") //release證書
                storePassword "test"                            //簽名證書密碼
                keyAlias "test"                                 //別名
                keyPassword "test"                              //別名密碼
            }
        }

        buildTypes {
            debug {
                buildConfigField("boolean", "LOG_ON", "true")//通過編譯類型配置日誌開關
                versionNameSuffix "-debug"                       //包名尾碼為“-debug”

                minifyEnabled false                              //是否混淆
                zipAlignEnabled false                            //Zipalign優化
                shrinkResources false                            // 移除無用的resource文件
                signingConfig signingConfigs.debug               //使用debug證書簽名
            }

            release {
                buildConfigField "boolean", "LOG_ON", "false" //不顯示Log

                minifyEnabled true                               //開啟混淆
                zipAlignEnabled true                             //開啟Zipalign優化
                shrinkResources true                             //移除無用的resource文件,此項只有在開啟混淆時才生效
                proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
                signingConfig signingConfigs.release             //使用release證書簽名

                //多渠道打包配置
                applicationVariants.all { variant ->
                    variant.outputs.each { output ->
                        def outputFile = output.outputFile
                        if (outputFile != null && outputFile.name.endsWith('.apk')) {
                            // 輸出apk名稱為test_v1.0_2016-08-15_wandoujia.apk
                            def fileName = "test_v${defaultConfig.versionName}_${releaseTime()}_${variant.productFlavors[0].name}.apk"
                            output.outputFile = new File(outputFile.parent, fileName)
                        }
                    }
                }
            }
        }

        // 渠道配置
        productFlavors {
            wandoujia {}
            _360 {}
            baidu {}
            xiaomi {}
        }

        productFlavors.all { flavor ->
            flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE: name] //動態地修改AndroidManifest中的渠道名
        }
    }

註:上述日誌開關,可以在java代碼中獲取該變數值,如:

if(BuildConfig.LOG_ON){
    Log.d("test","xxx");    
}

2. 美團打包方案

實現原理:Android應用安裝包apk文件是一個壓縮文件,可以將其尾碼改為zip直接解壓。解壓後會發現根目錄下有一個META-INF目錄。如果在META-INF目錄內添加空文件,應用無需重新簽名。因此,通過為不同渠道的應用添加不同的空文件,可以唯一標識一個渠道。 
採用這種方式,每打一個渠道包只需複製一個apk,在META-INF中添加一個使用渠道號命名的空文件即可。


深入學習

Android Studio系列教程六–Gradle多渠道打包

Android產品研發(五)–>多渠道打包

更便捷的 Android 多渠道打包方式

Android打包系列——多渠道快速打包

查看原文:http://blog.csdn.net/u010818425/article/details/52319382


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1. width:0; 光有高度是不行的,還得有寬度。缺點文字隱藏不了,可以加個 和背景顏色一樣就ok了,障眼法,迷惑人的,其實內容還在,如果有文字的話,還是可以觸發點擊事件的,這種做法很多黑客就會利用在目標站點鏈接上加一個和背景顏色一樣的讓管理員發現不了。 2. height:0; 和上面一樣,一 ...
  • 前幾天在院子里看了一個大牛用js寫了一個路由的,有一句代碼一直不知道怎麼回事,後來就自己寫了一個,寫的比較的粗糙,我覺得把面向對象的思想都搞得亂七八糟的,不過功能實現了. ...
  • 本文地址:http://www.cnblogs.com/wuyudong/p/5904528.html,轉載請註明源地址。 本文對之前手機衛士開發進行一個小結。 1、SplashActivity 版本名稱的展示,從清單配置文件中獲取版本名稱,PackageManager 服務端新版本的檢測(本地版本 ...
  • 文本框(UITextField) 本章節繼續編輯 JXHypnoNerd 。文件地址 。 首先我們繼續編輯 JXHypnosisViewController.m 修改 loadView 方法,向 view 中添加一個 UITextField 對象: 構建並運行應用,項目中會顯示一個文本框,該文本框就 ...
  • 本文地址:http://www.cnblogs.com/wuyudong/p/5903707.html,轉載請註明源地址。 在手機衛士之前的版本升級的對話框中: 有的用戶暫時不想更新,沒有點擊“稍後再說”,而是選擇點擊回退按鍵,那麼這時候的邏輯應該是讓用戶進入home界面而不是splash界面。所以 ...
  • Activity有些公共部分,比如setContentView、Activity管理、初始化操作、聯網操作、Activity跳轉、關閉當前Activity、保存用戶登錄信息、讀取用戶登錄信息等。 我們可以抽取成一個抽象類BaseActivity,再新建Activity的時候,繼承BaseActivi ...
  • 在介紹tcp發送函數之前得先介紹很關鍵的一個結構sk_buff,在linux中,sk_buff結構代表了一個報文: 然後見發送函數源碼,這裡不關註硬體支持的分散-聚集: 詳細的說明見註釋。 註意幾點主要的流程: 1.TCP以1mss為單元來發送數據,最大段大小基於MTU計算獲得,MTU是一個鏈路層的 ...
  • 在《Android 手機衛士--打包生成apk維護到伺服器》一文中,實現了新版本的apk到伺服器,當打開客戶端apk的時候,發現有新版本,提示更新。還實現了利用xutils工具實現了從伺服器端下載apk 本文地址:http://www.cnblogs.com/wuyudong/p/5903484.h ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...