【问题标题】:Cannot build signed android package through visual studio cordova无法通过 Visual Studio Cordova 构建签名的 android 包
【发布时间】:2026-01-17 07:55:02
【问题描述】:

我正在尝试使用 Visual Studio 2015 Cordova 工具为我的 Android 应用程序构建一个签名的发布包。 我正在使用 Cordova 5.1.1,它要求我为构建过程提供一个 build.json 文件,告诉应用程序密钥库在哪里以及正在使用什么密码。 但是,当我添加 build.json 文件时,我无法成功构建以发布。

我遵循了这个指南:https://github.com/Microsoft/cordova-docs/tree/master/tutorial-package-publish#android

得到了这个错误(路径被编辑):

1>  ANDROID_HOME=C:\Program Files (x86)\Android\android-sdk (TaskId:11)
1>  JAVA_HOME=C:\Program Files (x86)\Java\jdk1.7.0_55 (TaskId:11)
1>  \build.json (TaskId:11)
1>  Reading build config file: \build.json (TaskId:11)
1>  \platforms\android\cordova\node_modules\q\q.js:126 (TaskId:11)
1>                      throw e; (TaskId:11)
1>                            ^ (TaskId:11)
1>  SyntaxError: Unexpected token  (TaskId:11)
1>      at Object.parse (native) (TaskId:11)
1>      at parseOpts (\platforms\android\cordova\lib\build.js:475:27) (TaskId:11)
1>      at Object.module.exports.run (\platforms\android\cordova\lib\build.js:529:16) (TaskId:11)
1>      at \platforms\android\cordova\build:36:22 (TaskId:11)
1>      at _fulfilled (\platforms\android\cordova\node_modules\q\q.js:798:54) (TaskId:11)
1>      at self.promiseDispatch.done (\platforms\android\cordova\node_modules\q\q.js:827:30) (TaskId:11)
1>      at Promise.promise.promiseDispatch (\platforms\android\cordova\node_modules\q\q.js:760:13) (TaskId:11)
1>      at \platforms\android\cordova\node_modules\q\q.js:574:44 (TaskId:11)
1>      at flush (\platforms\android\cordova\node_modules\q\q.js:108:17) (TaskId:11)
1>      at process._tickCallback (node.js:355:11) (TaskId:11)
1>  Command finished with error code 1: cmd /s /c ""\platforms\android\cordova\build.bat" --release "--buildConfig=\build.json"" (TaskId:11)
1>ERROR building one of the platforms : error : cmd: Command failed with exit code 1
1>  You may not have the required environment or OS to build this project (TaskId:11)
1>MDAVSCLI : error : cmd: Command failed with exit code 1
1>Done executing task "MdaVsCli" -- FAILED. (TaskId:11)

我做错了什么?它似乎无法解析 JSON?

【问题讨论】:

    标签: android cordova visual-studio-2015 visual-studio-cordova


    【解决方案1】:

    这个问题是因为默认的 build.json 有一个 NodeJS JSON 解析器不喜欢的 BOM。您可以通过多种方式解决此问题,但最简单的是使用 Visual Studio 的二进制编辑器打开文件。

    右键单击 build.json,选择“打开方式...”,然后从列表中选择“二进制编辑器”。您应该会看到如下内容:

    选择屏幕截图中的前三个字节,然后删除它们,然后保存文件。解析器现在应该接受该文件,并且签名将按预期工作。

    【讨论】:

    • 我遇到了完全相同的问题,这已经为我解决了,谢谢!
    • 你是个巫师,dlev。
    • 这也解决了我的问题。没有具体迹象表明哪个标记或字符是意外的。但是,上面的修复就像一个魅力。
    • 谢谢你,这对我帮助很大
    • 谢谢这个答案节省了我很多时间。再次感谢。
    【解决方案2】:

    我也按照相同的文档尝试了这种方法。并得到完全相同的错误。

    查看android build documentation后,即Signing Your App Manually

    我意识到应该可以在发布模式下构建应用程序(即第一次生成未签名的 apk),所以我删除了 build.json 并尝试了这个,但我得到了错误。我做了一些谷歌搜索,然后找到了这个 [post][2]。

    [2]: Error when running cordova build –release android 总而言之这是我的建议。

    1. 删除 build.json 文件。
    2. 清理解决方案,将其设置为调试模式并确保您可以成功构建。
    3. 清理解决方案将其设置为释放模式。
    4. 转到您的应用程序目录,找到platforms\android,您将看到build.gradle。
    5. 创建一个新文件 build-extras.gradle,我从 [post][2] 上的一个中得到了这个建议

      [2]: Error when running cordova build –release android 你不想编辑自动生成的 build.gradle 文件。

    6. 在你的 build-extras.gradle 中放 android { lintOptions { 禁用 MissingTranslation } }
    7. 现在开始构建您的解决方案,它应该可以工作,您将在 bin\Android\release 文件夹中获得一个未签名的 apk,即 android-release-unsigned.apk。
      1. 按照android build - signing your app manually steps手动签署您的apk

    【讨论】:

    • 我知道我可以手动签名。我希望 Visual Studio 自动完成。这就是为什么我不会接受这个作为答案。
    • 我在使用 build.json 文件时遇到的错误正是不起作用。我想知道“Unexpected token ´╗┐”到底是什么意思,微软团队中负责这个的人应该调查一下。
    • 另一个破解方法是使用 build-extras.gradle
    【解决方案3】:

    除了@dlev 发布的原因之外,我还发现了另一个可能导致此问题的原因:

    我使用的路径包含文件夹名称foo\bar。这以前有效,但现在看来(我不知道节点、cordova 或其他是否已更新)这不再有效,您必须转义目录分隔符:foo\\bar

    添加后,我可以再次构建我的项目。

    【讨论】:

      【解决方案4】:

      另一个技巧是利用 android 的构建系统。在platforms\android 中,将您的密钥库文件放在您的build-extras.gradle 中。以下

       安卓 {
           lintOptions {
              checkReleaseBuilds 错误
              中止错误错误
          }
          签名配置 {
               发布 {
                      关键别名 = ""
                      keyPassword = "yourpassword" // 这些必须设置为非空才能将签名步骤添加到任务图中。
                      storeFile = file("yourfile.keystore")
                      storePassword = "你的密码"
                  }
              }
              构建类型 {
                  发布 {
                      签名配置 签名配置.release
                  }
              }
      }

      如果您想创建完全自动化的错觉,那么您可以使用 gulp 任务 "a pre-build step" 将您的密钥库文件和 build-extras gradle 文件从无论您拥有它们。

      【讨论】: