我正在尝试使用 Cordova/Phonegap 创建一个新的 Android 项目。
我已经下载了 cordova-2.9.0 和 ADT Bundle for Mac。
我将 ADT 提取到 ~/Developer/Android,并将其添加到我的路径中:
export PATH="$HOME/Development/Android/sdk/tools:$PATH"
export PATH="$HOME/Development/Android/sdk/platform-tools:$PATH"
然后我尝试运行 cordova create
脚本,但它失败了:
→ bin sudo ./create ~/Projects/myproject/cordova-android com.mydomain.myproject myproject
Password:
BUILD FAILED
/Users/asgeo1/Development/Android/sdk/tools/ant/build.xml:714: The following error occurred while executing this line:
/Users/asgeo1/Development/Android/sdk/tools/ant/build.xml:728: Compile failed; see the compiler error output for details.
Total time: 1 second
An unexpected error occurred: ant jar > /dev/null exited with 1
Deleting project...
帮助不大。因此,我编辑了 Cordova create
脚本,以便它输出更多信息。
# COMMENTED OUT piping to /dev/null:
#
# compile cordova.js and cordova.jar
pushd "$BUILD_PATH"/framework # > /dev/null
ant jar #> /dev/null
popd #> /dev/null
然后我重新运行 create
脚本:
→ bin sudo ./create ~/Projects/myproject/cordova-android com.mydomain.myproject myproject ~/Downloads/cordova-2.9.0/cordova-android/framework ~/Downloads/cordova-2.9.0/cordova-android/bin Buildfile: /Users/asgeo1/Downloads/cordova-2.9.0/cordova-android/framework/build.xml -pre-build: -check-env: [checkenv] Android SDK Tools Revision 22.0.5 [checkenv] Installed at /Users/asgeo1/Development/Android/sdk -setup: [echo] Project Name: Cordova [gettype] Project Type: Android Library -build-setup: [getbuildtools] Using latest Build Tools: 18.0.1 [echo] Resolving Build Target for Cordova... [gettarget] Project Target: Android 4.3 [gettarget] API level: 18 [echo] ---------- [echo] Creating output directories if needed... [echo] ---------- [echo] Resolving Dependencies for Cordova... [dependency] Library dependencies: [dependency] No Libraries [echo] ---------- [echo] Building Libraries with '${build.target}'... [subant] No sub-builds to iterate on -code-gen: [mergemanifest] No changes in the AndroidManifest files. [echo] Handling aidl files... [aidl] No AIDL files to compile. [echo] ---------- [echo] Handling RenderScript files... [renderscript] No RenderScript files to compile. [echo] ---------- [echo] Handling Resources... [aapt] No changed resources. R.java and Manifest.java untouched. [echo] ---------- [echo] Handling BuildConfig class... [buildconfig] Generating BuildConfig class. -pre-compile: -compile: [javac] Compiling 104 source files to /Users/asgeo1/Downloads/cordova-2.9.0/cordova-android/framework/bin/classes [javac] /Users/asgeo1/Downloads/cordova-2.9.0/cordova-android/framework/src/com/squareup/okhttp/Connection.java:171: method does not override a method from its superclass [javac] @Override public void close() throws IOException { [javac] ^
And there's another 40 errors like the one above, regarding @override
.
From what I can tell on Google, this is because in jdk 1.6 and above, the @override annotations changed. (or something like that): Why is javac failing on @Override annotation
OK, so I work out that the Android SDK configuration for ant
is in a file called build.xml
. Low and behold, it has some settings for Java 1.5:
<property name="java.target" value="1.5" />
<property name="java.source" value="1.5" />
如果我将这些值更改为 1.6 或 1.7,我会在重新运行 Cordova create
脚本时收到 java 错误:
-compile:
[javac] Compiling 104 source files to /Users/asgeo1/Downloads/cordova-2.9.0/cordova-android/framework/bin/classes
[javac] javac: invalid source release: 1.7
[javac] Usage: javac <options> <source files>
我真的在这里挠头。我不是 Java 专家,所以我不明白这里发生了什么。
有谁知道如何在 OSX 上为 Cordova Android 运行 create
脚本?
更新
在遵循@cartland 下面的建议后,我能够摆脱 @Override
错误。不过仍然出现最后一个错误:
-compile:
[javac] Compiling 104 source files to /Users/asgeo1/Downloads/cordova-2.9.0/cordova-android/framework/bin/classes
[javac] /Users/asgeo1/Downloads/cordova-2.9.0/cordova-android/framework/src/org/apache/cordova/InAppBrowser.java:523: error: cannot find symbol
[javac] settings.setPluginsEnabled(true);
[javac] ^
[javac] symbol: method setPluginsEnabled(boolean)
[javac] location: variable settings of type WebSettings
[javac] Note: Some input files use or override a deprecated API.
[javac] Note: Recompile with -Xlint:deprecation for details.
[javac] 1 error
我会尝试找出那是什么 - 但如果有人知道,请发布答案:)
更新 2
我知道第二个错误是什么。这里提到:https://developer.motorolasolutions.com/thread/3640
Cordova 2.9.0 与 Android SDK 18 不兼容。我需要将 Cordova 3.0.0 与 Android SDK 18 一起使用。(或者反过来将 Android SDK 降级到 17)
最佳答案
我正在运行 Ubuntu 10.4 64 位;甲骨文 JDK 1.7.0_25-b15; eclipse 开普勒;安卓SDK 4.3; PhoneGap 3.0。
遇到了与您使用 CLI 时完全相同的问题。将项目加载到 Eclipse 中工作正常(~/.cordova/lib/android/cordova/3.0.0/framework/.project)。由于 Eclipse 使用它自己的内部 Java 编译器,我认为我使用的 Oracle 安装存在问题,并且存在某种程度的问题。
事实证明,某些应用程序已将早期 JRE 中的 tools.jar(以及其他)版本安装到 Java ext 文件夹中。对我来说似乎很奇怪,javac 会在它自己的 lib 文件夹中的 jars 之前从这里加载依赖的 jars,但这似乎是优先顺序。不管怎样,我从 ext 文件夹中删除了所有文件,一切正常。
- JDK 位置:/usr/lib/jvm/java-7-oracle/
- 扩展位置:/usr/java/packages/lib/ext/
我没有我的 Mac 来检查位置,但尝试/Library/Java/Extensions 或 ~/Library/Java/Extensions
我不需要进行任何其他更改。然而,在试验时,我确实尝试在项目的 ant.properties 文件中设置以下属性。 1.5、1.6、1.7 都可以。
- java.target=1.5
- java.source=1.5
关于java - `create` Cordova Android 脚本无法创建新项目 - java/ant 配置错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18074522/