签名和发布应用程序
要想使Android应用程序在真机上运行,需要对apk(Android应用程序的执行文件,相当于Symbian程序的sis/sisx或Java ME程序的jar文件)文件进行签名。可以通过命令行或ADT插件方式对apk文件进行签名。本节将详细介绍签名过程。
使用命令行方式进行签名
使用命令行方式进行签名需要JDK中的两个命令行工具:keytool.exe和jarsigner.exe。可按如下两步对apk文件进行签名:
(1)使用keytool生成专用密钥(Private Key)文件。
(2)使用jarsigner根据keytool生成的专用密钥对apk文件进行签名。
生成专用密钥的命令如下:
- keytool -genkey -v -keystore androidguy-release.keystore
- -alias androidguy -keyalg RSA -validity 3000
在执行上面的命令后,需要输入一系列的信息。这些信息可以任意输入,但一般需要输入一些有意义的信息。下面是作者输入的信息:
- 输入keystore密码:
- 再次输入新密码:
- 您的名字与姓氏是什么?
- [Unknown]: lining
- 您的组织单位名称是什么?
- [Unknown]: nokiaguy.blogjava.net
- 您的组织名称是什么?
- [Unknown]: nokiaguy
- 您所在的城市或区域名称是什么?
- [Unknown]: shenyang
- 您所在的州或省份名称是什么?
- [Unknown]: liaoning
- 该单位的两字母国家代码是什么?
- [Unknown]: CN
- CN=lining, OU=nokiaguy.blogjava.net, O=nokiaguy,
- L=shenyang, ST=liaoning, C=CN 正确吗?
- [否]: Y
- 正在为以下对象生成 1,024 位 RSA 密钥对和自签名证书
- (SHA1withRSA)(有效期为 30,000 天):
- CN=lining, OU=nokiaguy.blogjava.net,
- O=nokiaguy, L=shenyang, ST=liaoning, C=CN
- 输入<androidguy>的主密码
- (如果和 keystore 密码相同,按回车):
- [正在存储 androidguy-release.keystore]
在输入完上面的信息后,在当前目录下会生成一个androidguy-release.keystore文件。这个文件就是专用密钥文件。
下面使用jarsigner命令对apk文件进行签名。首先找到本章实现的例子生成的apk文件。该文件在ch02_showdatetime\bin目录中,在Windows控制台进入该目录,并将刚才生成的androidguy-release.keystore文件复制到该目录中,最后执行如下命令:
- jarsigner -verbose -keystore androidguy-release.
- keystore ch02_showdatetime.apk androidguy