应用认领jarsigner签名问题总结

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/lkjfyy/article/details/79985837

最近项目上传小米市场,公司原因需要认领应用,小米需要提供一个签名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中的别名]

猜你喜欢

转载自blog.csdn.net/lkjfyy/article/details/79985837