友盟多渠道打包 Android Apk

本文详细介绍如何通过友盟+应用统计实现多渠道APK打包的过程。包括申请AppKey、集成SDK、配置manifest文件及Gradle脚本来实现针对不同应用市场的定制化打包。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目前项目中使用到了多渠道打包的功能,首先理解多渠道打包,渠道可理解成安卓apk应用市场平台,所以多渠道打包可以理解成在打包多个应用市场的apk,要在每个应用市场上打包一个安卓Apk,这样好处是可以在查看apk在每个安卓市场的下载量,活跃度,便于公司进行重点运营和推广,因为友盟多渠道统计比较成熟,所以公司采用的是友盟的多渠道打包统计;

点击官网 友盟+ 应用统计

多渠道打包的步骤:
1,首先去到上面官网为自己的应用申请Appkey
2,然后下载集成SDK,本人是使用AndroidStudio集成的,好处是直接在app Module 的build.gradle中添加如下依赖就可以:

dependencies {
   compile 'com.umeng.analytics:analytics:latest.integration'
}

3.manifest的配置主要包括添加权限,以下权限缺一不可,填写Appkey和填写渠道id三部分

<manifest……>
<uses-sdk android:minSdkVersion="8"></uses-sdk>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.READ_PHONE_STATE"/>
<application ……>
……
<activity ……/>
<meta-data android:value="YOUR_APP_KEY" android:name="UMENG_APPKEY"/>
<meta-data android:value="Channel ID" android:name="UMENG_CHANNEL"/>
</application>    
</manifest>

上面不清楚可以去到官网仔细浏览一遍;
从第三部开始 我自己Module 中 manifest的应用配置如下:

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>

        <meta-data
            android:name="UMENG_APPKEY"
            android:value="4f83c5d852701564c0000011" /><!--友盟 Appkey 自己应用注册申请来的-->
        <meta-data
            android:name="UMENG_CHANNEL"
            android:value="${UMENG_CHANNEL_VALUE}" /> <!--渠道号,多渠道这里使用了占位符$-->
    </application>

因为我们要在多个应用市场上面打包,所以这里的value的值我们不能写死,比如写huawei,这样只打华为应用市场的apk,而我们是多个市场的,所以这里使用占位符是动态获取;
下面要渠道app build.gradle中进行配置

1.首先要添加一个 渠道号

android {
    compileSdkVersion 25
    buildToolsVersion "25.0.2"
    defaultConfig {
        applicationId "multi_channel.shion.com.multichannel"
        minSdkVersion 9
        targetSdkVersion 25
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
        // AndroidManifest.xml 里面UMENG_CHANNEL的value为 ${UMENG_CHANNEL_VALUE}
        manifestPlaceholders = [UMENG_CHANNEL_VALUE: "umeng"]//添加一个默认渠道号
    }

2.配置打包相关

  //添加我们签名文件配置
    signingConfigs {
        debug {
            storeFile file("liverpool.jks")//key store
            storePassword "123456"
            keyAlias "multichannel"
            keyPassword "123456"
        }
        release {
            storeFile file("liverpool.jks")
            storePassword "123456"
            keyAlias "multichannel"
            keyPassword "123456"
        }
    }

    //打包相关配置
    buildTypes {
        debug {
            shrinkResources true // 移除无用的resource文件
            minifyEnabled false //不启用混淆
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro',
                    'proguard-fresco.pro'
            //签名配置
            signingConfig signingConfigs.debug
        }
        release {
            shrinkResources true // 移除无用的resource文件
            minifyEnabled false //不启用混淆
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
            //签名配置
            signingConfig signingConfigs.release
        }
    }

上面都有注释 打包相关配置buildTypes中分别配置了测试(debug)和发布(release),我们最主要关心的是签名配置 signingConfig 的值,我们都写在了signingConfigs的配置了,而且这个要写在 buildTypes 的上面,不然打包的时候会报如下错误:
这里写图片描述
至于 release { storeFile file("liverpool.jks") storePassword "123456" keyAlias "multichannel" keyPassword "123456" }
是我们申请apk打包的的时候都必须要自己弄得,(没搞过的话,自己随便建个工程打包就知道了)

3.下面就是最关键的部分了

配置多渠道打包:也是我们公司产品要发布的应用市场

 //多渠道打包支持
    productFlavors {
        Alpha {//自己打包测试使用
            //     manifestPlaceholders = [UMENG_CHANNEL_VALUE: Alpha]
        }
        Tencent {//投放应用宝市场
            //     manifestPlaceholders = [UMENG_CHANNEL_VALUE: Tencent]
        }
        Baidu {//投放百度市场
            //     manifestPlaceholders = [UMENG_CHANNEL_VALUE: Baidu]
        }
        Wandoujia {//投放豌豆荚市场
            //     manifestPlaceholders = [UMENG_CHANNEL_VALUE: Wandoujia]
        }
        PP {//投放PP助手市场
            //     manifestPlaceholders = [UMENG_CHANNEL_VALUE: PP]
        }
        Qihoo {//投放PP助手市场
            //     manifestPlaceholders = [UMENG_CHANNEL_VALUE: Qihoo]
        }
        Vivo {//投放vivo市场
            //     manifestPlaceholders = [UMENG_CHANNEL_VALUE: Vivo]
        }
        Oppo {//投放oppo市场
            //     manifestPlaceholders = [UMENG_CHANNEL_VALUE: Oppo]
        }
        Xiaomi {//投放小米市场
            //     manifestPlaceholders = [UMENG_CHANNEL_VALUE: Xiaomi]
        }
        Meizu {//投放魅族市场
            //     manifestPlaceholders = [UMENG_CHANNEL_VALUE: Meizu]
        }
        Huawei {//投放华为应用市场
            //     manifestPlaceholders = [UMENG_CHANNEL_VALUE: Huawei]
        }
        Lenovo {//投放联想市场
            //     manifestPlaceholders = [UMENG_CHANNEL_VALUE: Lenovo]
        }
        Letv {//投放乐视市场
            //     manifestPlaceholders = [UMENG_CHANNEL_VALUE: Letv]
        }
        Gionee {//投放金立市场
            //     manifestPlaceholders = [UMENG_CHANNEL_VALUE: Gionee]
        }
        HiMarket {//投放安卓市场
            //     manifestPlaceholders = [UMENG_CHANNEL_VALUE: HiMarket]
        }

    }
    //注意我注释掉的,可以去掉注释,那样的话,下面这句就可以不用了
    productFlavors.all {
        flavor -> flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE: name]
    }

解释:productFlavors 支持多渠道打包,使用它的话,可以为下面每一个市场打包一个apk,里面也是用了manifestPlaceholders 使用相关的值替换了UMENG_CHANNEL_VALUE
如果怕麻烦,可以像上面那样写使用

 productFlavors.all {
        flavor -> flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE: name]
    }

会遍历productFlavors下面所有的名称替换UMENG_CHANNEL_VALUE ;
最后使用gradlew assembleRelease 打生产包 ;gradlew assembleDebug 打测试包
这里写图片描述

这里写图片描述

这里写图片描述

点击此处下载实例Demo

渠道打包工具主要是提供基本的通过工程源码打包的功能。 常见错误见这里目前不支持的Apk特性见这里(可能会导致发布的SDK产生严重bug)。 Google 现在已经发布了最新的构建系统(New Building System) , 在 Android Studio 中已经支持了最新的 构建系统,如果开发者已经迁移,可以使用新的系统方面的生成渠道包,这是取代渠道打包工具的最佳方式。 1. 工程结构 工程结构图 : - CommonTools 共用的工具类,包括对 `Apktool` , `Jarsigner` , `zipalign` 的封装 - UIControls_35   共用的UI类,对大部分控件的样式都是在这里设置的 - UmengMarket  Marekt 组件,现在还没有实现 - UmengPackage 打包组件 - UmengTools 工程主要UI,管理 UmengMarket, UmengPackage, UmengTools 三个组件 - UmengWidget 小工具组件,目前仅有解包分析的功能 打包工具组件: - Source - Builder - ApkBuilder.cs     通过 APK 打包的 Builder 实现                    - Builder.cs            抽象 Builder 类,提供打包的主要逻辑                    - SourceBuilder.cs通过源码打包的 Builder 实现 (目前代码还没有实现)          - Worker.cs 打包过程对外接口 3. 打包流程 V2.0 版本仅实现了通过 .apk 打包的方式,本质上对  apk 文件进行反编译,修改 AndroidManifest.xml 文件后,再重新打包,我们使用的工具是开源的拆包工具 Apktool 将  apktool  添加到当前 process 的环境变量 执行 apktool d --no-src -f xxxx.apk temp 拆解apk 替换或者添加 AndroidManifest.xml 中的 channel 执行apktool b temp  unsigned.apk 重新打包apk 执行 SignApk.jar 生成签名后的 apk 文件 执行 zipAlign 生成对齐优化后的 apk 文件 回到 3 替换新的渠道 完成打包 使用  JarSigner.jar 给 Apk 签名, SignApk.jar  文件是我们修改过的 apk 签名工具,实现了和 ADT 中一样的签名方式,使用如下: Usage: signapk file.{keystore} keystore_password key_entry key_password input.apk output.apk
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值