51工具盒子

依楼听风雨
笑看云卷云舒,淡观潮起潮落

.NET MAUI Android在GitHub Actions上构建失败,错误代码为1。

英文:

.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.


赞(2)
未经允许不得转载:工具盒子 » .NET MAUI Android在GitHub Actions上构建失败,错误代码为1。