一个android项目开发完成之后要安装到设备上或者放到电子市场的话需要签名认证. 下面就详细简介android签名认证的过程及常见问题的解决.
1. 搭建java环境, 安装并配置jdk
2. 安装完成之后进行下列操作(本人jdk安装目录:D:\Program Files\Java\jdk1.6.0_18 )
2.1 生成keystore文件. 首先进入D:\Program Files\Java\jdk1.6.0_18\bin目录 (这目录下有两个文件: keytool.exe , jarsigner.exe . 签名就需要用到这两个工具)
执行命令: D:\Program Files\Java\jdk1.6.0_18\bin>keytool -genkey -v -keystore crack.keystore -alias android -keyalg RSA -validity 20000
出现的问题1:
完成之后. 但是在D:\Program Files\Java\jdk1.6.0_18\bin目录下始终找不到crack.keystore , 后来我将keystore文件保存指定目录.
2.2 签名认证: 生成完keystore文件之后, 进行签名认证执行如下命令:
D:\Program Files\Java\jdk1.6.0_18\bin>jarsigner -verbose -keystore crack.keystor e -signedjar CrackMe_signed.apk CrackMe.apk crack.keystore
出现问题2:
执行该命令之后总是报错: jarsigner: 找不到 crack.keystore 的证书链。crack.keystore 必须引用包 含专用密钥和相应的公共密钥证书链的有效密钥库密钥条目。
检查后发现: 步骤2.1中 keystore文件名与别名不一致造成, 故将步骤2.1指令更改如下:
keytool -genkey -v -keystore crack.keystore -alias crack.keystore -keyalg RSA -validity 20000 , 再执行步骤2.2就OK啦.