英文:
.NET MAUI Android Build Fails on GitHub Actions with jarsigner.exe Exited with Code 1
问题 {#heading}
摘要:
我正在尝试使用GitHub Actions构建和签名一个.NET MAUI Android应用程序。虽然在我的本地机器上一切正常,GitHub Actions工作流程在签名阶段遇到了与jarsigner.exe相关的错误。
问题:
错误信息:
C:\Program Files\dotnet\packs\Microsoft.Android.Sdk.Windows.0.68\tools\Xamarin.Android.Common.targets(2335,2): error MSB6006: "jarsigner.exe" exited with code 1. [D:\a\App.name\App.name\App.name\App.name.csproj::TargetFramework=net7.0-android]
工作流程的最后一部分:
- name: Setup Java
uses: actions/setup-java@v3
with:
distribution: 'microsoft'
java-version: '17'
`
`
* `name: Build
run: dotnet build App.name/App.name.csproj -c Release -f net7.0-android /p:AndroidSigningKeyPass=${{ secrets.KEYSTORE_PASSWORD }} /p:AndroidSigningStorePass=${{ secrets.KEYSTORE_PASSWORD_STORE }} --no-restore
`
附加信息:
- 密钥库文件已正确解密,并在GitHub secrets中可用。
- 使用的Java版本是来自Microsoft分发的17版本。
- 工作流程中的所有前面的步骤,包括依赖恢复和MAUI工作负载安装,都没有问题。是否有人遇到过类似的问题,或者能够解释在GitHub Actions中出现jarsigner.exe错误的原因?我是否应该共享整个.yaml文件?
英文:
Summary:
I'm attempting to build and sign a .NET MAUI Android app using GitHub Actions. While everything works perfectly on my local machine, and the GitHub Actions workflow runs smoothly up until the signing stage, I encounter an error related to jarsigner.exe during the build process on GitHub Actions.
The problem:
Error message
C:\Program Files\dotnet\packs\Microsoft.Android.Sdk.Windows.0.68\tools\Xamarin.Android.Common.targets(2335,2): error MSB6006: "jarsigner.exe" exited with code 1. [D:\a\App.name\App.name\App.name\App.name.csproj::TargetFramework=net7.0-android]
Last part of the workflow
- name: Setup Java
uses: actions/setup-java@v3
with:
distribution: 'microsoft'
java-version: '17'
`
`
* `name: Build
run: dotnet build App.name/App.name.csproj -c Release -f net7.0-android /p:AndroidSigningKeyPass=${{ secrets.KEYSTORE_PASSWORD }} /p:AndroidSigningStorePass=${{ secrets.KEYSTORE_PASSWORD_STORE }} --no-restore
`
Additional Information:
- The keystore file is correctly decrypted and available in the GitHub secrets
- Actions environment. The Java version being used is 17 from the
- Microsoft distribution. All preceding steps in the workflow, including dependency restoration and MAUI workload installation, complete without issues. Has anyone encountered a similar issue or can provide insights into what might be causing this error with jarsigner.exe on GitHub Actions?
Should I perhaps share the the entire .yaml file?
答案1 {#1}
得分: 0
好的,我来为你翻译以下内容:
好的,问题已解决。
在.csproj文件中删除密钥库配置,并将它们添加到命令中使其正常工作。
run: dotnet build App.name/App.name.csproj -c Release -f net7.0-android /p:AndroidKeyStore=true /p:AndroidSigningKeyStore=${{secrets.KEYSTORE}} /p:AndroidSigningKeyAlias=${{ secrets.KEYSTORE_ALIAS }} /p:AndroidSigningKeyPass=${{ secrets.KEYSTORE_PASSWORD }} /p:AndroidSigningStorePass=${{ secrets.KEYSTORE_PASSWORD }}
--no-restore
编辑:
必须删除/p:AndroidKeyStore=true
以避免出现错误。
编辑2:实际上,我重新添加了/p:AndroidKeyStore=true
。真正的问题在于我在哪个环境中运行gpg
命令以生成密钥库。
英文:
Ok, so I solved it.
Removing the keystore config in the .csproj file and adding them to the command made it worked.
run: dotnet build App.name/App.name.csproj -c Release -f net7.0-android /p:AndroidKeyStore=true /p:AndroidSigningKeyStore=${{secrets.KEYSTORE}} /p:AndroidSigningKeyAlias=${{ secrets.KEYSTORE_ALIAS }} /p:AndroidSigningKeyPass=${{ secrets.KEYSTORE_PASSWORD }} /p:AndroidSigningStorePass=${{ secrets.KEYSTORE_PASSWORD }}
--no-restore
Edit:
Had to remove /p:AndroidKeyStore=true
for it to not throw errors.
Edit 2: Actually I added /p:AndroidKeyStore=true
back. The real problem was in wich environment I was running the gpg
command for the keystore.