注意:本篇文章是本人阅读相关文章的总结,方便以后查阅,所有内容非原创,侵权删。
本篇文章内容来自于
1.Android第一行代码 郭霖
2.相对应的知识块的最下方会给出原来的帖子的链接
目录
- 打包带正式签名的APK
--1.1 使用AS自动生成
--1.2 使用Gradle生成
----1.2.1 Gradle生成APK操作流程
----1.2.2 加强保密性:将keystore信息配置在gradle.properties中 - 多渠道打包
--2.1 使用Gradle生成/使用AS自动生成
--2.2 使用三方多渠道打包(待补)
前言
Android系统会将所有的APK文件识别为应用程序的安装包,类似于windows的exe文件。
但并不是所有的apk文件都能成功安装到手机上,Android系统要求只有签名后的APK文件才可以安装。
通过AS将程序安装到手机上的背后流程:
AS会将程序代码打包成一个APK文件,然后将这个文件传输到手机上,最后再执行安装操作。其中AS使用了默认的keystore文件帮我们自动进行了签名。
默认的keystore文件在:点击AS右侧工具栏的Gradle->项目名->app:->Tasks->android 双击siginingReport,然后在控制台可以看到Store: /Users/apple/Desktop/androddemo/haha.jks
1. 打包带正式签名的APK
keyStore 密钥库路径
keyStore Password 密钥库密码
keyAlias 签名文件别名
keyPassword 签名文件密码
1.1 使用AS自动生成
点击Android studio导航栏的Build->Generate Signed APK
按照步骤进行生成
1.2 使用Gradle生成
1.2.1 Gradle生成APK操作流程
1.配置签名信息
编辑app/build.gradle文件
在android闭包中添加以下内容
android {
...
signingConfigs{
config{ //配置keystore文件的各种信息
storeFile file('/Users/apple/Desktop/androddemo/haha.jks') //指定keystore文件的位置
storePassword '123456' //密码
keyAlias 'key' //别名
keyPassword '123456' //别名密码
}
}
...
}
2.应用配置
即在生成正式版APK的时候去应用这个配置
编辑app/build. gradle文件
android {
...
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
signingConfig signingConfigs.config //应用刚才添加的签名配置
//则生成正式版APK的时候就会自动使用我们刚才配置的签名信息来进行签名了。
}
}
...
}
3.生成APK文件
点击AS右侧工具栏的Gradle->项目名->app:->Tasks->build
先clean清理当前项目,在双击assembleRelease,生成正式版APK
当提示控制台提示build successful,则成功
APK文件自动生成在app/build/outputs/apk目录下
app-release.apk就是带正式签名的APK文件
1.2.2 加强保密性:将keystore信息配置在gradle.properties中
根据以上的打包生成APK流程,目前keystore文件的所有信息都是以明文的形式直接配置在build.gradle中的,这样不太安全。
Android推荐的做法是将这类敏感数据配置在一个独立的文件里面,然后再在build.gradle中读取这些数据。
1.在gradle.properties中存放敏感数据
AS项目的根目录下有一个gradle.properties文件,专门用来配置全局键值对数据的。
则在gradle.properties中添加以下内容:
KEY_PATH=/Users/apple/Desktop/androddemo/haha.jks
KEY_PASS=123456
ALIAS_NAME=key
ALIAS_PASS=123456
2.在build.gradle中读取数据
编辑app/build.gradle
android {
...
signingConfigs{
config{ //配置keystore文件的各种信息
storeFile file(KEY_PATH)
storePassword KEY_PASS
keyAlias ALIAS_NAME
keyPassword ALIAS_PASS
}
}
...
}
3.将gradle.properties文件保护好
这样直接查看build.gradle文件是无法看到keystore文件的各种信息的,只有查看gradle.properties文件才能看得到。
然后我们只需要将gradle.properties文件保护好就可以了。比如将它从git版本控制中排除,这样gradle.properties文件只能保留在本地,从而不用担心keystore文件的信息泄漏。
2.多渠道打包
其实完全可以使用同一个APK文件来上架不同的应用商店,但是如果有一些特殊需求的话,比如针对不同的应用商店渠道来定制不同的界面,则差异化需求,则需要用到多渠道。
2.1 使用Gradle生成/使用AS自动生成
比如我们要生成百度和360两个渠道的APK文件
2.1.1 修改app/build.gradle文件 用于添加所有的渠道配置
android {
...
defaultConfig {
applicationId "com.example.apple.tempdemo1"
minSdkVersion 15
targetSdkVersion 26
versionCode 1
versionName "1.0"
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
}
flavorDimensions "versionCode"
//多渠道打包的
//添加productFlavors闭包,用于添加所有的渠道配置
productFlavors{
qihoo{
//渠道名中的闭包中可以复写defaultConfig的任何一个属性
applicationId "com.example.apple.systemdemo.qihoo"
//修改applicationId属性,则最终生成的各个渠道的APK文件的包名也不同
}
baidu{
applicationId "com.example.apple.systemdemo.baidu"
}
}
...
}
Error:All flavors must now belong to a named flavor dimension. Learn more at https://d.android.com/r/tools/flavorDimensions-missing-error-message.html
解决:在android闭包中加入
flavorDimensions "versionCode"
2.1.2.针对不同渠道编写差异性需求
在app/src目录下(main的平级目录),新建一个baidu目录,然后在baidu目录下再新建java和res两个目录。java用于存放代码,res目录用于存放资源。如果要重写AndroidManifest文件中的内容,则可在新建目录下再新建一个AndroidManifest.xml。
例子:不同渠道不同的应用名和应用图标
清单文件中的配置是
android:icon="@mipmap/pic1"
android:label="@string/app_name"
则在对应的渠道文件夹下放入想要差异化的资源
2.1.3 生成多渠道的APK文件
1. 使用Gradle生成
点击AS右侧工具栏的Gradle->项目名->app:->Tasks->build
此时会发现多出了几个新的Task
先clean清理当前项目,在双击assembleRelease,生成正式版APK
当提示控制台提示build successful,则成功
APK文件自动生成在app/build/outputs/apk目录下
app-release.apk就是带正式签名的APK文件
2. 使用AS可视化工具生成
点击Android studio导航栏的Build->Generate Signed APK
选择生成的时候会有多选