Java Unity Android uCommandInvokationFailure:无法将类转换为dex格式

Java Unity Android uCommandInvokationFailure:无法将类转换为dex格式,java,android,unity3d,ads,startapp,Java,Android,Unity3d,Ads,Startapp,我使用的是Windows7、JDK1.8.0(64位)、jre 8(64位)、Unity Pro 4.3.4f1和Android SDK 22.6.1 所有都是更新的软件。 所有这些都可以正常工作,但当我使用StartAppsdk时,会出现此错误。没有使用额外的插件,只有StartApp广告提供的SDK Error building Player: CommandInvokationFailure: Unable to convert classes into dex format. See t

我使用的是Windows7、JDK1.8.0(64位)、jre 8(64位)、Unity Pro 4.3.4f1和Android SDK 22.6.1

所有都是更新的软件。 所有这些都可以正常工作,但当我使用StartAppsdk时,会出现此错误。没有使用额外的插件,只有StartApp广告提供的SDK

Error building Player: CommandInvokationFailure: Unable to convert classes into dex format. See the Console for details.
C:\Program Files\Java\jdk1.8.0\bin\java.exe -Xmx1024M -Dcom.android.sdkmanager.toolsdir="D:/android-sdks\tools" -Dfile.encoding=UTF8 -jar "C:/Program Files (x86)/Unity/Editor/Data/BuildTargetTools/AndroidPlayer\sdktools.jar" -

stderr[

UNEXPECTED TOP-LEVEL EXCEPTION:
java.lang.IllegalArgumentException: already added: Lcom/unity3d/player/a$1;
    at com.android.dx.dex.file.ClassDefsSection.add(ClassDefsSection.java:122)
    at com.android.dx.dex.file.DexFile.add(DexFile.java:161)
    at com.android.dx.command.dexer.Main.processClass(Main.java:685)
    at com.android.dx.command.dexer.Main.processFileBytes(Main.java:634)
    at com.android.dx.command.dexer.Main.access$600(Main.java:78)
    at com.android.dx.command.dexer.Main$1.processFileBytes(Main.java:572)
    at com.android.dx.cf.direct.ClassPathOpener.processArchive(ClassPathOpener.java:284)
    at com.android.dx.cf.direct.ClassPathOpener.processOne(ClassPathOpener.java:166)
    at com.android.dx.cf.direct.ClassPathOpener.processDirectory(ClassPathOpener.java:229)
    at com.android.dx.cf.direct.ClassPathOpener.processOne(ClassPathOpener.java:158)
    at com.android.dx.cf.direct.ClassPathOpener.process(ClassPathOpener.java:144)
    at com.android.dx.command.dexer.Main.processOne(Main.java:596)
    at com.android.dx.command.dexer.Main.processAllFiles(Main.java:498)
    at com.android.dx.command.dexer.Main.runMonoDex(Main.java:264)
    at com.android.dx.command.dexer.Main.run(Main.java:230)
    at com.android.dx.command.dexer.Main.main(Main.java:199)
    at com.android.dx.command.Main.main(Main.java:103)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:483)
    at SDKMain.main(SDKMain.java:129)
1 error; aborting
]

我已经尝试过JAVA_OPT和JAVA_HOME解决方案。但仍然无法解决

我使用Intellij13.1.4和JDK1.6遇到了这个问题,但我猜这是由任何其他IDE上的相同问题引起的->类.jar被多次引用/包含

检查并确保添加到项目中的classes.jar(来自Unity\Editor\Data\PlaybackEngines\androidplayer\bin\classes.jar)没有被多次引用/包含。如果进入文件->项目结构: 库下应该只有一个“类”。 不应该引用工件下的类(工件用于创建plugin.jar文件)

查看此相关答案->

我的问题实际上与文件重复有关。虽然不是真的重复,但我有两个adMob sdk包(不同版本),它们之间存在冲突。删除旧版本后,所有内容都已修复。您是否正在使用任何第三方SDK或类似软件,如果是,请尝试删除它们(如果可能),并查看问题是否仍然存在。尝试找出导致这种情况发生的代码的哪一部分。您最终可以尝试编译一个空项目,只用于测试。

今天,我解决了构建播放器时出现的类似错误:CommandInvokationFailure:无法将类转换为dex格式。有关详细信息,请参阅控制台。将.jar文件添加到Plugins\Android中\

我犯了不同的错误:

  • 原因:com.android.dx.cf.iface.ParseException:错误的类文件魔术(cafebabe)或版本(0034.0000
  • 原因:com.android.dx.cf.iface.ParseException:类名(ht/string/test)与路径(src/ht/string/test.class)不匹配
  • 我的工作解决方案类似于:

    代码在这里:

    verysimple\src\ht\stringing\test.java
    
    我有:

    别忘了在播放器设置中比较你的“最低Api级别”。对我来说,它是安卓4.0.3…(15)

    > javac -classpath "c:\Android\sdk\platforms\android-15" ht\stringing\test.java
    > jar cvf ..\dist\verysimple.jar ht\stringing\test.class
    > copy  ..\dist\verysimple.jar c:\ExUnityApp\Assets\Plugins\Android