0

Android SDK を r22 に更新しました。更新に問題があったことは承知していますが、Eclipse 用の Android ADT に重点を置いています。今日一日くらい頭を悩ませてきた私の問題は、バウンシーキャッスルと関係があります

PhoneGap アプリケーションを構築しています。この更新まではすべて問題ありませんでしたが、現在は構築に失敗しています。

コマンド ラインを使用してアプリケーションをビルドしています (PhoneGap の /cordova フォルダーにあるビルド ツールを使用)。

私が得るエラーは次のとおりです。

BUILD FAILED
/Users/rhystague/Development/mobile-dev/android-dev/android-sdk-macosx/tools/ant/build.xml:955: The following error occurred while executing this line:
/Users/rhystague/Development/mobile-dev/android-dev/android-sdk-macosx/tools/ant/build.xml:966: The following error occurred while executing this line: 
/Users/rhystague/Development/mobile-dev/android-dev/android-sdk-macosx/tools/ant/build.xml:310: java.lang.VerifyError: class org.bouncycastle.asn1.ASN1Primitive overrides final method equals.(Ljava/lang/Object;)Z

この後、スタックトレースを取得します。この質問の一番下に入れました。

これは私の環境と私が試したことです。

環境

Mac OS X 10.8.4
Java 1.6
Java 1.7

Mac OS 10.8.4 では、Java のインストール場所が異なります。入力すると:

which java
I get :/usr/bin/java

java -version
1.6 Version

/usr/libexec/java_home
/System/Library/Java/JavaVirtualMachines/1.6.0.jdk/Content/Home

To run the 1.7 version I have to go to it's home directly which is 
/Library/Internet plugins/JavaAppletPlugin.plugin/Contents/Home

私のコンピューターにあるライブラリ、Bouncy Castle (bcprov-jdk15-143.jar)に問題がある可能性があることがわかりました。これらの手順を試してみたところ、Java の ClassDefNotDefined 問題だけが発生しました。

ファイルをプロジェクトの libs フォルダーに移動しようとしましたが、それが修正されるかどうかを確認しようとしましたが、何もありませんでした。

ライブラリを最新バージョンの Bouncy Castle (bcprov-jdk15-on-149.jar) に更新しようとしましたが、Java で ClassDefNotDefined しか取得できませんでした。

設定のせいかなと思って、新しいフォンギャップアプリを試してみましたが、やはり同じ問題です。

正直なところ、私は Java のパワー プレーヤーではないので、基本的なことしか知りません。たぶんそれは単純かもしれませんし、それとも何か他のものかもしれません。

いずれにせよ、私は自分の足で私を止めました。何もテストできません。

以下は、エラーが吐き出された後のスタック トレースです。

at java.lang.ClassLoader.defineClass1(Native Method)
    at java.lang.ClassLoader.defineClassCond(ClassLoader.java:631)
    at java.lang.ClassLoader.defineClass(ClassLoader.java:615)
    at org.apache.tools.ant.AntClassLoader.defineClassFromData(AntClassLoader.java:1128)
    at org.apache.tools.ant.AntClassLoader.getClassFromStream(AntClassLoader.java:1299)
    at org.apache.tools.ant.AntClassLoader.findClassInComponents(AntClassLoader.java:1355)
    at org.apache.tools.ant.AntClassLoader.findClass(AntClassLoader.java:1315)
    at org.apache.tools.ant.AntClassLoader.loadClass(AntClassLoader.java:1068)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:247)
    at com.android.sdklib.build.ApkBuilder.init(ApkBuilder.java:446)
    at com.android.sdklib.build.ApkBuilder.<init>(ApkBuilder.java:394)
    at com.android.ant.ApkBuilderTask.execute(ApkBuilderTask.java:334)
    at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:291)
    at sun.reflect.GeneratedMethodAccessor4.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106)
    at org.apache.tools.ant.Task.perform(Task.java:348)
    at org.apache.tools.ant.taskdefs.Sequential.execute(Sequential.java:68)
    at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:291)
    at sun.reflect.GeneratedMethodAccessor4.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106)
    at org.apache.tools.ant.Task.perform(Task.java:348)
    at org.apache.tools.ant.taskdefs.MacroInstance.execute(MacroInstance.java:398)
    at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:291)
    at sun.reflect.GeneratedMethodAccessor4.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106)
    at org.apache.tools.ant.Task.perform(Task.java:348)
    at org.apache.tools.ant.taskdefs.Sequential.execute(Sequential.java:68)
    at com.android.ant.IfElseTask.execute(IfElseTask.java:124)
    at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:291)
    at sun.reflect.GeneratedMethodAccessor4.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106)
    at org.apache.tools.ant.Task.perform(Task.java:348)
    at org.apache.tools.ant.taskdefs.Sequential.execute(Sequential.java:68)
    at com.android.ant.IfElseTask.execute(IfElseTask.java:124)
    at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:291)
    at sun.reflect.GeneratedMethodAccessor4.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106)
    at org.apache.tools.ant.Task.perform(Task.java:348)
    at org.apache.tools.ant.taskdefs.Sequential.execute(Sequential.java:68)
    at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:291)
    at sun.reflect.GeneratedMethodAccessor4.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106)
    at org.apache.tools.ant.Task.perform(Task.java:348)
    at org.apache.tools.ant.taskdefs.MacroInstance.execute(MacroInstance.java:398)
    at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:291)
    at sun.reflect.GeneratedMethodAccessor4.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106)
    at org.apache.tools.ant.Task.perform(Task.java:348)
    at org.apache.tools.ant.Target.execute(Target.java:392)
    at org.apache.tools.ant.Target.performTasks(Target.java:413)
    at org.apache.tools.ant.Project.executeSortedTargets(Project.java:1399)
    at org.apache.tools.ant.Project.executeTarget(Project.java:1368)
    at org.apache.tools.ant.helper.DefaultExecutor.executeTargets(DefaultExecutor.java:41)
    at org.apache.tools.ant.Project.executeTargets(Project.java:1251)
    at org.apache.tools.ant.Main.runBuild(Main.java:811)
    at org.apache.tools.ant.Main.startAnt(Main.java:217)
    at org.apache.tools.ant.launch.Launcher.run(Launcher.java:280)
    at org.apache.tools.ant.launch.Launcher.main(Launcher.java:109)
4

2 に答える 2

2

Phonegap android ビルド (phonegap run androidバージョン 3 の新しいコマンドを使用) をビルドする際にこの問題が発生し、Bouncy Castle のバージョンが下にあることがわかりまし/Library/Java/Extensionsた。過去に、ここに JAR をインストールすると他の JAR と競合するという問題がありました。

bc*.jarこのフォルダーからファイルを移動すると、Android Phonegap アプリのビルドが正常に開始されました。

これらのライブラリは、他のアプリケーション/ツールによってそこに配置されている可能性があることに注意してください.

于 2013-07-25T00:07:28.803 に答える
0

Android でサポートされていない追加機能が必要な場合は、SpongyCastleを使用してみてください。

于 2013-07-11T00:23:29.077 に答える