Android.PublishApplication
发布应用
3. 为App签名
Android 要求App在安装前,需要使用证书(certificate)来进行数字签名(be digitally signed).
Android 用证书来标识一个App的作者或者开发商。该证书不需要由证书管理机构(certificate authority)来签发。
Android app 经常使用自签发的证书(self-signed certificate)。App开发者来保存证书的私钥。
3.1 在debug模式下签名
不能发布一个在debug模式下签名的app。Android Studio 和 ADT plugin for Eclipse在debug模式下
自动为你的app进行签名。
3.2 在release模式下签名
在release模式下,用自己的证书为自己的app签名,步骤:
1 创建keystore。keystore是一个包含了一组私钥的二进制文件。keystore必须保存
在安全可靠的地方。
2 创建私钥。私钥代表随app被标识的实体,实体可以是人或者公司。
3 构建project。为app生成一个未签名的apk。
4 签名app。用你的私钥来生成apk的签名版本。
在完成这个过程后,可以发布你的app。
keystore和private key需要放在安全可靠的地方,并且有可靠的备份。
如果发布app到Google Play,然后丢失了用来签名app的private key,那么就无法对该app进行更新。
因此必须用同一个key来对所有的版本进行签名。
3.3 在Android Studio中进行签名 (略)
3.4 在ADT中进行签名 (略)
3.5 签名的考虑因素
3.6 保证私钥的安全
3.7 debug证书的过期
3.8 手动对app进行签名
可以使用Android SDK 和 JDK的工具在命令行为app进行签名。
1.用keytool创建私钥
$ keytool -genkey -v -keystore my-release-key.keystore -alias alias_name -keyalg RSA -keysize 2048 -validity 10000
10000天有效期,生成一个keystore:my-release-key.keystore。 该keystore包含一个key,alias_name是key的名字。
2.在release模式下编译app来获得一个未签名的apk。
3.用jarsigner和私钥来对app进行签名:
$ jarsigner -verbose -sigalg SHAwithRSA -digestalg SHA1 -keystore my-release-key.keystore my_application.apk alias_name
可以用不同的key来对apk进行多次签名。
4. 确认apk已被签名:
$ jarsigner -verify -verbose -certs my_application.apk
5. 用zipalign对齐apk包
$ zipalign -v 4 your_project_name-unaligned.apk your_project_name.apk
4. 使用ant自动化Android App的构建过程
4.1 创建构建文件build.xml
ant 类似make工具,build.xml 类似makefile文件
使用android工具来创建build.xml文件。
4.2 创建ant.properites文件
注:在自动化构建中使用jarsigner
在用ant构建工具来构建app时,可以通过ant.properties来为jarsigner提供参数,例如
key.store.password=storepass
key.alias.password=aliaspass
key.store=path/to/keystore
key.alias=alias_name
4.3
jarsigner -verify xxx.apk
笔者的jdk版本是: java version "1.6.0_65"。由于在Mac OS X运行上面的命令,jarsigner是乱码,bad grammar
请同事在同事机器上运行上面的命令,有以下输出:
"jar 已验证。
警告:
此 jar 包含证书链未验证的条目。
有关详细信息, 请使用 -verbose 和 -certs 选项重新运行。"
该问题原因参见Ref[3]。
Reference:
1. jarsigner
http://docs.oracle.com/javase/7/docs/technotes/tools/windows/jarsigner.html
2. 在ant中提供password来直接自动化构建
http://stackoverflow.com/questions/9932498/signing-applications-automatically-with-password-in-ant
3. 此 jar 包含证书链未验证的条目
http://stackoverflow.com/questions/8387983/jarsigner-this-jar-contains-entries-whose-certificate-chain-is-not-validated
Android.PublishApplication的更多相关文章
- 【原】Android热更新开源项目Tinker源码解析系列之三:so热更新
本系列将从以下三个方面对Tinker进行源码解析: Android热更新开源项目Tinker源码解析系列之一:Dex热更新 Android热更新开源项目Tinker源码解析系列之二:资源文件热更新 A ...
- 配置android sdk 环境
1:下载adnroid sdk安装包 官方下载地址无法打开,没有vpn,使用下面这个地址下载,地址:http://www.android-studio.org/
- Android SwipeRefreshLayout 下拉刷新——Hi_博客 Android App 开发笔记
以前写下拉刷新 感觉好费劲,要判断ListView是否滚到顶部,还要加载头布局,还要控制 头布局的状态,等等一大堆.感觉麻烦死了.今天学习了SwipeRefreshLayout 的用法,来分享一下,有 ...
- Android Studio配置 AndroidAnnotations——Hi_博客 Android App 开发笔记
以前用Eclicps 用习惯了现在 想学学 用Android Studio 两天的钻研终于 在我电脑上装了一个Android Studio 并完成了AndroidAnnotations 的配置. An ...
- Android请求网络共通类——Hi_博客 Android App 开发笔记
今天 ,来分享一下 ,一个博客App的开发过程,以前也没开发过这种类型App 的经验,求大神们轻点喷. 首先我们要创建一个Andriod 项目 因为要从网络请求数据所以我们先来一个请求网络的共通类. ...
- 【原】Android热更新开源项目Tinker源码解析系列之一:Dex热更新
[原]Android热更新开源项目Tinker源码解析系列之一:Dex热更新 Tinker是微信的第一个开源项目,主要用于安卓应用bug的热修复和功能的迭代. Tinker github地址:http ...
- 【原】Android热更新开源项目Tinker源码解析系列之二:资源文件热更新
上一篇文章介绍了Dex文件的热更新流程,本文将会分析Tinker中对资源文件的热更新流程. 同Dex,资源文件的热更新同样包括三个部分:资源补丁生成,资源补丁合成及资源补丁加载. 本系列将从以下三个方 ...
- Android Studio 多个编译环境配置 多渠道打包 APK输出配置
看完这篇你学到什么: 熟悉gradle的构建配置 熟悉代码构建环境的目录结构,你知道的不仅仅是只有src/main 开发.生成环境等等环境可以任意切换打包 多渠道打包 APK输出文件配置 需求 一般我 ...
- JS调用Android、Ios原生控件
在上一篇博客中已经和大家聊了,关于JS与Android.Ios原生控件之间相互通信的详细代码实现,今天我们一起聊一下JS调用Android.Ios通信的相同点和不同点,以便帮助我们在进行混合式开发时, ...
随机推荐
- 使用pickle进行存储变量
有时候我们需要把我们的变量内容存下来,这时我们就可以用pickle来操作. 存储操作如下所示: #!/usr/bin/python # -*- coding:utf-8 -*- import pick ...
- jquery val() text() html()的区别
value()主要用在表单元素上,如果其他的元素获取value是通过attract()的方法,text()是获取元素的纯文本,如果text(“content”)就会更改元素的文本内容:html()获取 ...
- linux系统上项目部署
步骤:(特别注意:虚拟机安装的一般是32位的操作系统,jdk也必须使用32位的)查看虚拟机版本:sudo uname --m i686 //表示是32位 x86_64 // 表示是64位 查看是否已经 ...
- 04_web基础(五)之cookie与session
29.Http协议无记忆带来的问题 什么是会话:可简单理解为:用户开一个浏览器,访问某一个web站点,在这个站点点击多个超链接,访问服务器多个web资源,然后关闭浏览器,整个过程称之为一次会话. 在一 ...
- ss源码学习--事件处理
为了方便区分,以下分别使用local,server,remote代表ss客户端,ss服务端,以及ss客户端请求访问的远程主机. 在shadowsocks中,无论对于local还是server,都需要建 ...
- 10大H5前端框架(转)
10大H5前端框架 作为一名做为在前端死缠烂打6年并且懒到不行的攻城士,这几年我还是阅过很多同门从知名到很知名的各种前端框架,本来想拿15-20个框架来分享一下,但在跟几个前辈讨教写文章的技巧时果断被 ...
- leetcode 中等题(1)
2. Add Two Numbers(中等) /** * Definition for singly-linked list. * struct ListNode { * int val; * Lis ...
- 第十章 优先级队列 (xa3)左式堆:插入与删除
- 区间dp 51nod1021
题目链接:https://www.51nod.com/Challenge/ProblemSubmitDetail.html#!#judgeId=673021 代码: 参考博客:https://blog ...
- Android Studio生成签名安装包(Generate Signed APK)
一 打开构建对话框. 二 创建新的密钥库(key store) 可以选择已创建的密钥库,也可以选择创建新的密钥库. 创建完成后,自动导入. 三 选择签名类型. 如果不选,会提示错误. 这里将新旧两种签 ...