2012-07-28 2 views
8

PREAMBLE : SDK 레벨 16부터 Android에 내장 된 Zeroconf 구현이 있습니다. 청동기 시대와의 호환성이 문제가 아니라면 jmDNS를 더 이상 사용하지 말고 대신 NsdManager을 사용하십시오.jmDNS가있는 Android 빌드가 실패합니다.


프리앰블 # 2 : NsdManager의 초기 버전은 SO getSystemService(Context.NSD_SERVICE) freezes the 5.0 emulator 질문을 참조 고장이 가득하고 링크 된 버그를 기록합니다.


Android 프로젝트에 jmDNS 3.4.1을 추가했습니다. JAR을 lib 아래로 복사 한 다음 "Java BuildPath"/ Library에서 참조를 추가했습니다.

[2012-07-27 22:59:07 - Yarxi] Dx 
UNEXPECTED TOP-LEVEL EXCEPTION: 
java.lang.IllegalArgumentException: already added: Lcom/strangeberry/jmdns/tools/Browser$1; 
at 

com.android.dx.dex.file.ClassDefsSection.add(ClassDefsSection.java:123) 
    at com.android.dx.dex.file.DexFile.add(DexFile.java:163) 
    at com.android.dx.command.dexer.Main.processClass(Main.java:486) 
    at com.android.dx.command.dexer.Main.processFileBytes(Main.java:455) 
    at com.android.dx.command.dexer.Main.access$400(Main.java:67) 
    at com.android.dx.command.dexer.Main$1.processFileBytes(Main.java:394) 
    at com.android.dx.cf.direct.ClassPathOpener.processArchive(ClassPathOpener.java:245) 
    at com.android.dx.cf.direct.ClassPathOpener.processOne(ClassPathOpener.java:131) 
    at com.android.dx.cf.direct.ClassPathOpener.process(ClassPathOpener.java:109) 
    at com.android.dx.command.dexer.Main.processOne(Main.java:418) 
    at com.android.dx.command.dexer.Main.processAllFiles(Main.java:329) 
    at com.android.dx.command.dexer.Main.run(Main.java:206) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) 
    at java.lang.reflect.Method.invoke(Unknown Source) 
    at com.android.ide.eclipse.adt.internal.build.DexWrapper.run(DexWrapper.java:180) 
    at com.android.ide.eclipse.adt.internal.build.BuildHelper.executeDx(BuildHelper.java:703) 
    at com.android.ide.eclipse.adt.internal.build.builders.PostCompilerBuilder.build(PostCompilerBuilder.java:577) 
    at org.eclipse.core.internal.events.BuildManager$2.run(BuildManager.java:728) 
    at org.eclipse.core.runtime.SafeRunner.run(SafeRunner.java:42) 
    at org.eclipse.core.internal.events.BuildManager.basicBuild(BuildManager.java:199) 
    at org.eclipse.core.internal.events.BuildManager.basicBuild(BuildManager.java:321) 
    at org.eclipse.core.internal.events.BuildManager.build(BuildManager.java:396) 
    at org.eclipse.core.internal.resources.Project$1.run(Project.java:618) 
    at org.eclipse.core.internal.resources.Workspace.run(Workspace.java:2344) 
    at org.eclipse.core.internal.resources.Project.internalBuild(Project.java:597) 
    at org.eclipse.core.internal.resources.Project.build(Project.java:124) 
    at com.android.ide.eclipse.adt.internal.project.ProjectHelper.doFullIncrementalDebugBuild(ProjectHelper.java:1000) 
    at com.android.ide.eclipse.adt.internal.launch.LaunchConfigDelegate.launch(LaunchConfigDelegate.java:147) 
    at org.eclipse.debug.internal.core.LaunchConfiguration.launch(LaunchConfiguration.java:854) 
    at org.eclipse.debug.internal.core.LaunchConfiguration.launch(LaunchConfiguration.java:703) 
    at org.eclipse.debug.internal.ui.DebugUIPlugin.buildAndLaunch(DebugUIPlugin.java:937) 
    at org.eclipse.debug.internal.ui.DebugUIPlugin$8.run(DebugUIPlugin.java:1141) 
    at org.eclipse.core.internal.jobs.Worker.run(Worker.java:54) 
[2012-07-27 22:59:10 - Yarxi] Dx 1 error; aborting 
[2012-07-27 22:59:10 - Yarxi] Conversion to Dalvik format failed with error 1 

을 내가 참조 된 라이브러리에서 패키지 탐색기에서 JAR의 내용을 볼 때, 나는 볼 것을 jmdns의 모든 패키지에서 모든 클래스 :

지금 내 빌드 콘솔에서 다음과 같은 메시지와 함께 실패합니다. 항아리는 두 번 나열됩니다. JmDNS.class의 사본 2 개, JmmDNS.class의 사본 2 개 등.

무엇이 그릇에 문제가 있습니까? 나는이 프로젝트에서 다른 항아리를 사용하고 있으며, 아무도 이런 식으로 행동하지 않습니다. 몇 번 청소를 시도하고 JAR을 제거하고 다시 추가 한 동일한 효과.

이 프로젝트는 라이브러리 프로젝트이므로 라이브러리를 참조하는 앱을 빌드 할 때 오류가 발생합니다.

+0

PREAMBLE을 이용해 주셔서 감사합니다. 또한 NsdManager를 사용하기 시작했으며 긍정적 인 경험을했습니다. NsdManager가 JmDNS를 완전히 대체 할 수 있는지 궁금해했습니다. – Hong

+0

NsdManager에는 고유 한 문제가 있습니다. http://stackoverflow.com/questions/27281340/getsystemservicecontext-nsd-service-freezes-the-5-0-emulator –

+0

처음에 제가 몇 가지 논점을 언급했지만 문제가있는 것으로 보입니다. 지금 안정. 기능면에서 NmdManager를 JmDNS로 대체 할 수 있습니까? JmDNS를 매우 간략하게 사용한 다음 NsdManager로 전환하여 JmDNS가 많은 기능을 가진 것으로 보입니다. – Hong

답변

15

아마도 SourceForge의 .jar를 사용했을 것입니다. 이 버전은 모든 .class 파일이 .jar에 두 번 나타나며 이로 인해 오류가 발생합니다.

Maven http://search.maven.org/#browse|1991004139의 .jar를 사용해보세요. 이번 달 초에 사용해 보았습니다.

+0

니스, 고마워. 도움이되었습니다. +1 – uerceg