博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android Studio 打包Apk
阅读量:6247 次
发布时间:2019-06-22

本文共 3272 字,大约阅读时间需要 10 分钟。

  • 本文是转存自 FoolishDev的Android Studio 打包Apk, 。
  • 本文只为自己做个记录,方便以后查找。如若侵权,请告知,将第一时间删除。

以下为正文

Android Studio 打包

开发完一款Application之后,需要对其进行打包,才可以发布工用户使用(release)。而Android Studio就具备了打包的工具。有一下两种打包方式:

  • Gradle配置打包
  • Build->Generate Signed APK打包

签名文件

在进行打包之前,首先需要一个签名文件。

eclipse的签名文件是以.ketstore为后缀的文件;Android Studio是以.jks为后缀的文件。

签名文件有几个要素

英文名称 解释
keyStore 密钥库路径
keyStore Password 密钥库密码
keyAlias 签名文件别名
keyPassword 签名文件密码

默认签名文件

在开发阶段,用到第三方SDK新建应用项目时,需要签名KEY的SHA1。这里可以使用Android Studio自带的debug.keystore。 可以使用命令

keytool -list -v -keystore ~/.android/debug.keystore -alias androiddebugkey -storepass android -keypass android

在终端中直接获取到签名key的SHA1信息,如下图:

~代表的是账户的根目录

对应要素:

要素名称
keystore ~/.android/debug.keystore
keyStore password android
keyAlias androiddebugkey
keyPassword android

默认路径下的debug.keystore不存在时,会自动创建。如果修改了debug.keystore路径,并不会在新路径下自动创建debug.keystore文件。如果在默认路径创建一个不以debug命名的key,系统还是会自动创建该签名文件。所以只有使用默认路径,才会自动创建相应的key文件

参考,

创建签名文件生成Apk文件

通过Build->Generate Signed APK,选择module然后next,点击creat new...选项创建一个新的key文件。如下图填写一些基本信息

名称 描述
key store path 密钥库路径
password 密钥库密码
confirm 确认密码
alias 别名
validity 有效年限
first and last name 名字
organization unit 公司或组织
organization 公司
city or locality
state or province 市或洲
country code 国家代码

然后点击next->选择Build Type->Finish。此时Apk文件就生成了,同时签名文件也生成在相应目录。这里注意到,已经利用了Build->Generate Signed APK打包了Apk 。

参考

打包

打包有两种方式,在介绍自定义签名文件时,已经实现了一种打包方式:Build->Generate Signed APK 。那么来看看如何利用Gradle配置打包

Gradle 配置

配置签名文件

在build.gradle(module:app)中加入下面的代码

signingConfigs {    release {         storeFile file("foolishdev.jks")         storePassword "9445118798"         keyAlias "foolishdev"         keyPassword "9445118798"     } }复制代码

这里要输入的信息都是之前创建签名文件时对应的四个要素的值。

配置Build Type

buile type{     release {         // 不显示Log         buildConfigField "boolean", "LOG_DEBUG", "false"         //混淆         minifyEnabled true         //Zipalign优化         zipAlignEnabled true         // 移除无用的resource文件         shrinkResources true         //加载默认混淆配置文件         proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'         //签名         signingConfig signingConfigs.release     }}复制代码

通过signingConfig signingConfigs.release 来配置Build Type的签名信息。可以看到这里使用了Gradle配置签名文件时配置的Key。

其实android studio中module默认都会有debug和release两个buildType。debug用于开发时测试的版本,而release则是用来发布的版本。当然在这里也可以配置自定义的版本,并配置特有的签名文件。在Build Variants操作框中会生成该Build Type。

配置Build Variants

从上图操作框中可以看到,module的Build Variants中有两个Type,分别是debug和release。其中release是刚刚配置的Build Type。可以选择任意一个类型进行打包,并且他们会利用各自配置的Key进行打包。

注意到上面Build Type时并没有配置debug type,是Android Studio默认自带的。其中debug type使用的就是默认的签名文件(debug.keystore)。当然也可以在Build Type中配置debug Type并且配置自定义的debug key

生成Apk文件

当准备工作全部完成,执行 Run app或者Build->Build apk就会自动在module name/app/build/outputs/apk路径下生成Apk文件。 注意使用Build->Generate Signed APK生成Apk时,Apk文件生成目录和创建的Key文件目录相同

参考

进阶

不在Gradle中配置password

signingConfigs { //gradle assembleRelease      myConfig {         storeFile file("stone.keystore")         storePassword System.console().readLine("\nKeystore password: ")         keyAlias "stone"         keyPassword System.console().readLine("\nKey password: ")     } }复制代码

这样在执行gradle 命令$ gradle assembleRelease 时会被要求输入密码

参考

作者:FoolishDev链接:http://www.jianshu.com/p/7e5b1bacc35c來源:简书著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

转载于:https://juejin.im/post/5a31de8a6fb9a044fe4660ec

你可能感兴趣的文章
iftop-流量监控安装(脚本)
查看>>
Windows Server2008通过命令行方式添加防火墙规则
查看>>
我的友情链接
查看>>
2013年十大IT趋势预测
查看>>
用PySpider搜集2017年高校招生章程
查看>>
centos知识点巩固
查看>>
如何用scapy针对无线网络
查看>>
使用BeanNameAutoProxyCreator实现方法日志代理
查看>>
我的友情链接
查看>>
javascript变量的作用域
查看>>
CakePHP 2.x CookBook 中文版 第七章 模型 之 保存数据(二)
查看>>
第8章 三路由不同网段互通实验(中级篇)
查看>>
【啊哈!算法】最快最简单的排序——桶排序
查看>>
运城数据恢复注册了一个网站
查看>>
shell脚本菜
查看>>
ubuntu jdk安装配置
查看>>
分布式系统若干经验总结
查看>>
使用JSONP解决跨域问题-代码示例
查看>>
golang Tag
查看>>
云端时代桌面云架构介绍(CTVI)
查看>>