Phonegap / Cordova构建android node_modules / q / q.js throw e;

时间:2014-11-06 15:49:15

标签: android cordova ant ionic node-modules

cordova build android给了我以下错误

node_modules/q/q.js:126 throw e; (*error details)

之前已经问过这个问题,但关于PATH和ANDROID_HOME的典型答案对我没有用。

我已将其放入代码段以避免SO提交问题

export HOME="/Users/rover"
export ANDROID_SDK="$HOME/Documents/Dev/Android/adt-bundle-mac-x86_64-20140702/sdk"
export ANDROID_HOME="$ANDROID_SDK/tools"
export ANDROID_PLATFORM_TOOLS="$ANDROID_SDK/platform-tools"
export PATH="$ANDROID_HOME:$ANDROID_PLATFORM_TOOLS:$ANDROID_SDK/build-tools:$PATH"
export ANT_HOME="/usr/local/bin/ant"
#export PATH="$PATH:$ANT_HOME/bin"

我的环境变量:

$ set | grep“ANDROID \ | PATH”

ANDROID_HOME = /用户/流动站/文件/开发/ Android设备/ ADT-束-MAC-x86_64-20140702 / SDK /工具 ANDROID_PLATFORM_TOOLS = /用户/流动站/文件/开发/ Android设备/ ADT-束-MAC-x86_64-20140702 / SDK /平台的工具 ANDROID_SDK = /用户/流动站/文件/开发/ Android设备/ ADT-束-MAC-x86_64-20140702 / SDK PATH = /用户/流动站/文件/开发/ Android设备/ ADT-束-MAC-x86_64-20140702 / SDK /工具:/用户/流动站/文件/开发/ Android设备/ ADT-束-MAC-x86_64-20140702 / SDK /平台的工具:/用户/流动站/文档/开发/安卓/ ADT-束-MAC-x86_64-20140702 / SDK /编译工具:在/ usr / local / bin目录:在/ usr / bin中:/ bin中:/ usr / sbin目录:/ sbin目录中:/ opt / X11 / bin中

$ which ant
/usr/local/bin/ant
$ ls /usr/local/bin/ant
/usr/local/bin/ant

$ cordova --version
4.0.0

$ ant -v
Apache Ant(TM) version 1.9.4

我使用的是Mac OSX 10.10(Yosemite),这可能与Java 8有问题。这可能是相关的吗?

$ java -version java版“1.8.0_05” Java(TM)SE运行时环境(版本1.8.0_05-b13) Java HotSpot(TM)64位服务器VM(内置25.5-b02,混合模式)

$ ant --execdebug
exec "/Library/Java/JavaVirtualMachines/jdk1.8.0_05.jdk/Contents/Home/jre/bin/java" -classpath "/usr/local/Cellar/ant/1.9.4/libexec/lib/ant-launcher.jar" -Dant.home="/usr/local/Cellar/ant/1.9.4/libexec" -Dant.library.dir="/usr/local/Cellar/ant/1.9.4/libexec/lib" org.apache.tools.ant.launch.Launcher -cp ""

(*error details)

BUILD FAILED
/Users/rover/Documents/Dev/Android/adt-bundle-mac-x86_64-20140702/sdk/tools/ant/build.xml:653: The following error occurred while executing this line:
/Users/rover/Documents/Dev/Android/adt-bundle-mac-x86_64-20140702/sdk/tools/ant/build.xml:698: null returned: 1

Total time: 1 second

/Library/WebServer/Documents/Booster/core_ionic_git/platforms/android/cordova/node_modules/q/q.js:126
                    throw e;
                          ^
Error code 1 for command: ant with args: debug,-f,/Library/WebServer/Documents/Booster/core_ionic_git/platforms/android/build.xml,-Dout.dir=ant-build,-Dgen.absolute.dir=ant-gen
Error: /Library/WebServer/Documents/Booster/core_ionic_git/platforms/android/cordova/build: Command failed with exit code 8
    at ChildProcess.whenDone (/usr/local/lib/node_modules/cordova/node_modules/cordova-lib/src/cordova/superspawn.js:135:23)
    at ChildProcess.emit (events.js:98:17)
    at maybeClose (child_process.js:756:16)
    at Process.ChildProcess._handle.onexit (child_process.js:823:5)

有关解决这个问题的任何想法吗?

8 个答案:

答案 0 :(得分:20)

我把头撞在墙上几个小时,最终找到了一个简单的解决方案。我进入了项目目录并发出了两个命令:

cordova platform remove android
cordova platform add android

使用“cordova build android”重新编译,它就像一个魅力。

我认为cordova想要更新一些文件。

===== Ionic的更新========

如果您正在使用离子框架,那么这些是您救援的命令:

ionic platform remove android
ionic platform add android

我注意到这通常在你打破(Ctrl-C)编译过程时发生。

答案 1 :(得分:9)

我注意到您的ANDROID_HOME变量可能设置不正确 - 据我所知,它应该设置为SDK文件夹的根目录(你将ANDROID_SDK设置为),尝试一下(并确保你仍然你的路径上有$ ANDROID_HOME / tools和$ ANDROID_HOME / platform-tools。

答案 2 :(得分:2)

我遇到同样的问题并通过转义config.xml中的非字母字符来解决它。特别适用于name属性:

<name>Temps d'espera</name>

我把它改为:

<name>Temps d\'espera</name>

然后它完美运行。希望它有所帮助。

答案 3 :(得分:1)

@mylord我有类似的错误,这是由于无效的调试证书。在Linux上删除〜/ .android debug.keystore文件。

下次构建时,构建工具将重新生成新的密钥库和调试密钥。

这为我解决了。我希望这会有所帮助。

答案 4 :(得分:1)

我在运行&#39; phonegap serve&#39;时遇到了同样的问题,但解决方案却截然不同。我注意到当我重新启动计算机时操作会起作用。万一其他人遇到这个问题。这是Ubuntu 15上的解决方案

echo fs.inotify.max_user_watches=524288 | sudo tee -a /etc/sysctl.conf && sudo sysctl -p

取自stackoverflow线程Grunt watch error - Waiting...Fatal error: watch ENOSPC

除了海报错误,我还有错误

at exports._errnoException (util.js:856:11)
at FSWatcher.start (fs.js:1313:19)
at Object.fs.watch (fs.js:1341:11)

进一步向下。

答案 5 :(得分:0)

我遇到同样的错误信息,但我的ANDROID_HOME设置是正确的。 我发现错误是由我在\ platforms \ android \ ant-build文件夹中打开.apk文件引起的。关闭占用.apk文件的7zip之后,ant build通过了。

答案 6 :(得分:0)

在更改任何内容之前,制作一个空的cordova项目并尝试构建它,您可以发现问题是项目特定与否。

经过大量的更改后,我发现我们不应该有两个名称相同的文件夹:jqueryjQuery

答案 7 :(得分:0)

我有同样的问题。这是因为安装在Android设备上的应用程序具有相同的名称(在我的情况下具有相同的反向样式域名),该应用程序源自Google Play商店(这是我们的Beta版本)。