如果您使用 Java keystone 来签署您的 Android 应用程序(无论是否基于 Xamarin),则 99.999% 的可能性是XXX.keystore
您用来签署您的Xamarin.Android
应用程序是
已经是 JKS 格式而不是 PKCS12 格式。
一种快速检查方法是将您的梯形校正转储为 RFC 格式并查看Keystore type:
field.
Example:
/usr/bin/keytool -list -rfc -keystore debug.keystore |grep "Keystore type"
Output:
Enter keystore password:
***************** WARNING WARNING WARNING *****************
* The integrity of the information stored in your keystore *
* has NOT been verified! In order to verify its integrity, *
* you must provide your keystore password. *
***************** WARNING WARNING WARNING *****************
Keystore type: JKS
Warning:
The JKS keystore uses a proprietary format. It is recommended to migrate to PKCS12 which is an industry standard format using "keytool -importkeystore -srckeystore debug.keystore -destkeystore debug.keystore -deststoretype pkcs12".
示例(未过滤):
/usr/bin/keytool -list -rfc -keystore sushi.keystore
Output:
Enter keystore password:
***************** WARNING WARNING WARNING *****************
* The integrity of the information stored in your keystore *
* has NOT been verified! In order to verify its integrity, *
* you must provide your keystore password. *
***************** WARNING WARNING WARNING *****************
Keystore type: JKS
Keystore provider: SUN
Your keystore contains 1 entry
Alias name: androiddebugkey
Creation date: Aug 20, 2017
Entry type: PrivateKeyEntry
Certificate chain length: 1
Certificate[1]:
-----BEGIN CERTIFICATE-----
MIIDDTCCAfWgAwIBAgIEeCTY/jANBgkqhkiG9w0BAQsFADA3MQswCQYDVQQGEwJV
~~~~
KvHIbSHVBsryiyCwPJkXP6A=
-----END CERTIFICATE-----
*******************************************
*******************************************
如果您确实需要将 PKCS12 类型存储转换为新的 JKS 密钥存储类型文件:
keytool -importkeystore -srckeystore somekeystore.pkcs12 -destkeystore somenewkeystore.jks -deststoretype jks