发布应用

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

更多相关文章

  1. Android日志工具
  2. Android反编译工具:Apktool,支持Linux 、Windows下工作
  3. Android https 证书信任问题
  4. android 实用sax 读取xml文件内容 附源码
  5. 谷歌开发工具android studio启动不了的解决方法
  6. android遍历sd卡中的所有文件
  7. Android 实现多个Audio文件的顺序播放

随机推荐

  1. android摇一摇功能实现
  2. android:背景选择器-selector
  3. Android 中提高代码安全性-混淆代码
  4. Android NestedScrolling解决滑动冲突问
  5. android中使用gif
  6. Android的raw下视频文件的读写-日记
  7. 关于安卓屏幕切换的过程
  8. Android获取外置sdcard路径
  9. win平台改代码到android 平台需要注意
  10. Android为什么会有65536的方法数量限制