2013-02-08 81 views
0

我有以下问题:我做了一个Java应用程序,它在Netbeans运行时完全正常工作,但在构建后无法工作。该库已经适当地包括,这里是试图从命令行运行它之后会发生什么:Netbeans 7.2.1构建问题

Exception in thread "Thread-4" java.lang.NoClassDefFoundError: org/slf4j/LoggerFactory 
    at com.xuggle.ferry.JNIMemoryManager.<init>(JNIMemoryManager.java:861) 
    at com.xuggle.ferry.JNIMemoryManager.<clinit>(JNIMemoryManager.java:860) 

    at com.xuggle.mediatool.MediaWriter.<clinit>(MediaWriter.java:119) 
    at com.xuggle.mediatool.ToolFactory.makeWriter(ToolFactory.java:149) 
    at app.RepaintImpl$1.run(RepaintImpl.java:63) 
    at java.lang.Thread.run(Thread.java:722) 
Caused by: java.lang.ClassNotFoundException: org.slf4j.LoggerFactory 
    at java.net.URLClassLoader$1.run(URLClassLoader.java:366) 
    at java.net.URLClassLoader$1.run(URLClassLoader.java:355) 
    at java.security.AccessController.doPrivileged(Native Method) 
    at java.net.URLClassLoader.findClass(URLClassLoader.java:354) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:423) 
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:356) 
    ... 6 more 

在NB一切都被设置为JDK 7,我相信我的环境变量也没关系:

CLASSPATH=C:\Program Files\Java\jre7\lib\*;C:\Program Files\Java\jre7\bin\*; 
JAVA_HOME=C:\Program Files\Java\jdk1.7.0_09 
PATH=C:\Program Files\Java\jdk1.7.0_09\bin;... 

这里的生成日志,让我困扰的是,在Netbeans的.jar文件创建空目录的事实:

ant -f "C:\\Users\\Wojtek\\Documents\\NetBeansProjects\\VNC Streamer" clean jar 
init: 
deps-clean: 
Updating property file: C:\Users\Wojtek\Documents\NetBeansProjects\VNC Streamer\build\built-clean.properties 
Deleting directory C:\Users\Wojtek\Documents\NetBeansProjects\VNC Streamer\build 
clean: 
init: 
deps-jar: 
Created dir: C:\Users\Wojtek\Documents\NetBeansProjects\VNC Streamer\build 
Updating property file: C:\Users\Wojtek\Documents\NetBeansProjects\VNC Streamer\build\built-jar.properties 
Created dir: C:\Users\Wojtek\Documents\NetBeansProjects\VNC Streamer\build\classes 
Created dir: C:\Users\Wojtek\Documents\NetBeansProjects\VNC Streamer\build\empty 
Created dir: C:\Users\Wojtek\Documents\NetBeansProjects\VNC Streamer\build\generated-sources\ap-source-output 
Compiling 87 source files to C:\Users\Wojtek\Documents\NetBeansProjects\VNC Streamer\build\classes 
Note: C:\Users\Wojtek\Documents\NetBeansProjects\VNC Streamer\src\app\RepaintImpl.java uses or overrides a deprecated API. 
Note: Recompile with -Xlint:deprecation for details. 
Note: Some input files use unchecked or unsafe operations. 
Note: Recompile with -Xlint:unchecked for details. 
Copying 1 file to C:\Users\Wojtek\Documents\NetBeansProjects\VNC Streamer\build\classes 
Copied 25 empty directories to 24 empty directories under C:\Users\Wojtek\Documents\NetBeansProjects\VNC Streamer\build\classes 
compile: 
Created dir: C:\Users\Wojtek\Documents\NetBeansProjects\VNC Streamer\dist 
Copying 1 file to C:\Users\Wojtek\Documents\NetBeansProjects\VNC Streamer\build 
Copy libraries to C:\Users\Wojtek\Documents\NetBeansProjects\VNC Streamer\dist\lib. 
Building jar: C:\Users\Wojtek\Documents\NetBeansProjects\VNC Streamer\dist\VNC_Streamer.jar 
To run this application from the command line without Ant, try: 
java -jar "C:\Users\Wojtek\Documents\NetBeansProjects\VNC Streamer\dist\VNC_Streamer.jar" 
jar: 
BUILD SUCCESSFUL (total time: 7 seconds) 

任何帮助将不胜感激!

+0

你运行'java -jar“C:\ Users \ Wojtek \ Documents \ NetBeansProjects \ VNC Streamer \ dist \ VNC_Streamer.jar”'?这似乎是一个图书馆失踪。你可能只在运行选项卡中添加一个库(在项目属性中),但不是编译选项卡? – assylias

+0

是的,这些错误来自命令行后执行该文件。此外,我检查了属性,一切似乎都已到位。 – user1937873

+0

我会首先删除'CLASSPATH'变量,因为这是一个古老的做法,它可能会导致其他设置的问题。 – madth3

回答

1

在构建目录中驻留生成的jar和目录lib。

所以班级路径应该包含./lib。这可以在META-INF/MANIFEST.MF的主jar中设置为Class-Path,所以你不需要从命令行添加它。 用7zip进入罐子。

当前运行必须从具有主jar和lib子目录的(build)目录中发生。

顺便说一下,不需要环境类路径来包含JRE的bin。

+0

尝试在清单文件中设置类路径仍然没有帮助。 – user1937873