最近项目上传小米市场,公司原因需要认领应用,小米需要提供一个签名apk文件,没得说,按小米文档说明进行签名,遇到了几个问题这里记录一下,以供后期参考:
小米文档windows端jarsigner命令说明:jarsigner -verbose -keystore [您的私钥存放路径]-signedjar [签名后文件存放路径] [未签名的文件路径] [您的证书名称]
小米应用认领链接:https://dev.mi.com/console/doc/detail?pId=882
根据小米文档的说明,我先运行了以下命令进入我下载的存放小米未签名apk文件的文件夹中,不知道这一步能不能省略,我没测试
cd D:\Documents\Downloads\xiaomi
以下是遇到的各种问题:
1、jarsigner 错误: java.lang.RuntimeException: 密钥库加载: Invalid keystore format
我输入的命令为:
jarsigner -verbose -keystore D:\mykeystore\test -signedjar D:\Documents\Downloads\xiaomi\xiaomi.apk D:\Documents\Downloads\xiaomi\unsigned.apk test
出现原因:这里我用的签名文件是android studio生成的jks文件,因为我输入的keystore路径少写了test.jks,也就是完整的keystore路径为:D:\mykeystore\test\test.jks
2、只能指定一个别名 请键入 jarsigner -help 以了解用法
我输入的命令为:
jarsigner -verbose -keystore D:\mykeystore\test\test.jks -signedjar D:\Documents\Downloads\xiaomi\xiaomi.apk D:\Documents\Downloads\ xiaomi\unsigned.apk test
这个就有点搞笑了,一般很少注意到,只是因为你输入的输出或者输入apk文件的绝对路径不小心加了个空格
3、jarsigner: 找不到fanya的证书链。fanya必须引用包含私有密钥和相应的公共密钥证书链 的有效密钥库密钥条目。
这个错误估计是大家遇到比较多的,因为根据小米官方文档说明,最后一个参数是 [您的证书名称],其实应该是[您的证书的别名]
我的正确的jarsigner命令:
jarsigner -verbose -keystore D:\mykeystore\test\test.jks -signedjar D:\Documents\Downloads\xiaomi\xiaomi.apk D:\Documents\Downloads\ xiaomi\unsigned.apk mytest
最后给出正确的jarsigner签名命令:
jarsigner -verbose -keystore [keystore文件绝对路径] -signedjar [签名以后的apk文件绝对路径] [要签名的apk文件绝对路径] [keystore中的别名]