我正在尝试使用Cordova / Phonegap创建一个新的Android项目。
我已经下载了cordova-2.9.0和ADT Bundle for Mac。
我将ADT解压缩到〜/ Developer / Android,并将其添加到我的PATH:
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] ^
还有另外40个错误,如上面的错误,关于@override
。
据我所知,这是因为在jdk 1.6及以上版本中,@ override注释发生了变化。 (或类似的东西): Why is javac failing on @Override annotation
好的,所以我发现ant
的Android SDK配置位于名为build.xml
的文件中。很低,它有一些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)
答案 0 :(得分:4)
我正在运行Ubuntu 10.4 64bit; Oracle JDK 1.7.0_25-b15; Eclipse Kepler; Android 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文件夹中加载来自此处的依赖jar,但这似乎是优先顺序。无论如何,我从ext文件夹中删除了所有文件,一切正常。
我没有让我的Mac检查位置,但尝试/ Library / Java / Extensions或〜/ Library / Java / Extensions
我不需要做任何其他更改。但是在试验时,我确实尝试在项目的ant.properties文件中设置以下属性。所有的工作都是1.5,1.6,1.7。
答案 1 :(得分:0)
实际上,这里的问题似乎是你的java版本和Cordova编译的jar之间的不兼容性。 要快速修复,最好安装Java 1.5并将其用于开发。不要忘记将build.xml中的更改恢复为1.5。