Eri*_*ric 6 keytool visual-studio xamarin.android google-play apksigner
在 Visual Studio 中创建 APK 时出现此错误:
Failed to load signer "signer #1": C:\...\googleplay.keystore entry "googleplay" does not contain a key
Run Code Online (Sandbox Code Playgroud)
我是熟悉 Visual Studio 的长期 ASP.NET 开发人员,但这是我的第一个 Xamarin 项目。(我没有使用 Android Studio。)我正在尝试将 Android 版本部署到 Google Play。我从来没有上传过APK到Google Play,所以我无法使用Visual Studio的自动部署;我必须首先按照 Google 和 Microsoft 的说明执行手动部署。
我正在使用 JDK 1.8 运行 Visual Studio 2017 15.7.5(最新)。我的项目使用 NETStandard.Library 2.0.3、Xamarin.Forms 3.1.0 和 Microsoft.EntityFrameworkCore 2.1.1。
这个问题类似于这个没有答案的问题,但我从 Visual Studio 中收到错误。如果这是重复的,我深表歉意,但我无法添加有关该问题的其他详细信息。
我正在使用 Google Play 应用签名。我已经通过 Google Play 创建了一个密钥。我下载了 .der 格式的证书。我使用 keytool(来自 c:\Program Files\Java\jdk1.8.0_172\bin)使用以下命令将 .der 文件转换为 .keystore:
keytool -importcert -alias googleplay -file "C:\...\deployment_cert.der"
Run Code Online (Sandbox Code Playgroud)
我已经多次重新运行此实用程序更改了选项,认为 keytool 提示的别名或密码中的特殊字符可能存在区分大小写的问题。在这种情况下,别名全是字母,全是小写,密码是全小写的字母数字。keytool 要求信任此证书,然后我按“y”。
这会生成一个名为.keystore. 我将其重命名为googleplay.keystore,并将其移至更合适的位置。
我可以googleplay通过运行以下命令来仔细检查别名是否存在于密钥库文件中:
C:\Program Files\Java\jdk1.8.0_172\bin>keytool -v -list -keystore "C:\...\googleplay.keystore" -alias googleplay
Enter keystore password:
Alias name: googleplay
Creation date: Jul 23, 2018
Entry type: trustedCertEntry
Owner: CN=Android, OU=Android, O=Google Inc., L=Mountain View, ST=California, C=US
Issuer: CN=Android, OU=Android, O=Google Inc., L=Mountain View, ST=California, C=US
Serial number: e8************************************8a
Valid from: Thu Jul 19 14:18:56 EDT 2018 until: Sun Jul 19 14:18:56 EDT 2048
Certificate fingerprints:
MD5: 0D:**:**:**:**:**:**:**:**:**:**:**:**:**:**:C8
SHA1: 11:**:**:**:**:**:**:**:**:**:**:**:**:**:**:**:**:**:**:CD
SHA256: D0:**:**:**:**:**:**:**:**:**:**:**:**:**:**:**:**:**:**:**:**:**:**:**:**:**:**:**:**:**:**:74
Signature algorithm name: SHA256withRSA
Subject Public Key Algorithm: 4096-bit RSA key
Version: 3
Extensions:
#1: ObjectId: 2.5.29.19 Criticality=false
BasicConstraints:[
CA:true
PathLen:2147483647
]
Run Code Online (Sandbox Code Playgroud)
“googleplay”别名绝对存在!证书指纹与 Google 给我的密钥相匹配(已编辑)。
在 Visual Studio 中,我将解决方案配置设置为发布模式,我清理了我的整个解决方案(成功),重建了我的整个解决方案(成功),然后右键单击了我的 Android 项目并Archive...按照这些说明单击。
附带说明一下,微软的那篇文章非常令人沮丧,因为它没有提到签名或这个问题,而且他们关于签名的文章与 Google Play 的运作方式不符,似乎假设您已经将正确的 APK 上传到 Google Play(绕过鸡或蛋的Catch-22)。
起初我得到的是The archiving process has failed. Please see the Errors section for more details. 错误列表面板是空的。“输出”面板只是说"java.exe" exited with code 2. 我去了Tools -> Options -> Projects and Solutions -> Build and Run并MSBuild project build output verbosity从Minimal到Diagnostic并重复了最后几个步骤(清理、重建、存档)。现在,输出面板(略有编辑)说:
Using "AndroidApkSigner" task from assembly "C:\...\MSBuild\Xamarin\Android\Xamarin.Android.Build.Tasks.dll".
Task "AndroidApkSigner"
AndroidApkSigner:
ApkSignerJar: C:\Program Files (x86)\Android\android-sdk\build-tools\27.0.3\lib\apksigner.jar
ApkToSign: bin\Release\com.mycompany.myproject.apk
ManifestFile: obj\Release\android\AndroidManifest.xml
AdditionalArguments:
C:\Program Files\Java\jdk1.8.0_172\\bin\java.exe -jar "C:\Program Files (x86)\Android\android-sdk\build-tools\27.0.3\lib\apksigner.jar" sign --ks "C:\...\googleplay.keystore" --ks-pass pass:******** --ks-key-alias googleplay --key-pass pass:******** --min-sdk-version 19 --max-sdk-version 27 C:\...\myproject.Android\bin\Release\com.mycompany.myproject.apk
Failed to load signer "signer #1": C:\...\googleplay.keystore entry "googleplay" does not contain a key
"java.exe" exited with code 2.
Done executing task "AndroidApkSigner" -- FAILED.
Done building target "_Sign" in project "myproject.Android.csproj" -- FAILED.
Done building project "myproject.Android.csproj" -- FAILED.
Build FAILED.
Run Code Online (Sandbox Code Playgroud)
从上面的输出中,您可以看到我的项目属性的 Android 包签名选项卡中的(编辑)值是什么。通过反复试验,我发现密钥库密码、别名和别名密码都是必需的。我将密钥库密码和别名密码设置为相同,因为只有一个密码与此密钥库相关联。如上所述,密码是小写字母数字(在另一个 SO 问题的建议之后没有特殊字符)。
当 keytool 毫无问题地找到密钥时,为什么 AndroidApkSigner 无法在提供的别名的密钥库中找到密钥?
而且,我不能是唯一一个遇到这个问题的人吗?从 Visual Studio 部署到 Google Play 应该是一个相当常见的工作流程,但我没有找到其他人(除了这个其他未回答的 SO 问题)遇到这个问题。我究竟做错了什么?
我已经找到了我的问题的答案。Android 开发人员网站上的文档不适用于 Visual Studio。Xamarin 自带的 ApkSigner 不知道该怎么办。相反,使用它来创建您自己的发布密钥:
keytool -v -list -keystore c:\temp\myreleasekey.keystore -alias myalias -storetype pkcs12
Run Code Online (Sandbox Code Playgroud)
注意-storetype pkcs12最后的。此命令还被修改为(1)将文件写入程序文件之外的某个位置,(2)使用.keystoreVisual Studio 喜欢的扩展名,以及(3)避免别名中的特殊字符,这是 Visual Studio 不喜欢的,据我所知读。(密码中也应避免使用特殊字符。)
注意,keytool位于c:\Program Files\Java\jdk[version]\bin.
当我按照文档中的说明进行操作时,我收到了以下警告keytool:
警告:JKS 密钥库使用专有格式。建议迁移到 PKCS12,这是使用
keytool -importkeystore -srckeystore c:\temp\myreleasekey.jks -destkeystore c:\temp\myreleasekey.jks -deststoretype pkcs12.
当验证密钥是否正确时,我也收到此警告:
keytool -v -list -keystore c:\temp\myreleasekey.jks -alias myalias
Run Code Online (Sandbox Code Playgroud)
如果您有现有密钥并需要转换它,请按照警告中的命令进行操作。
我要感谢尼克解释签名和区分所有密钥背后的原因。
乔恩,谢谢你指导我如何创建自己的私钥。
| 归档时间: |
|
| 查看次数: |
6143 次 |
| 最近记录: |