尝试执行jar时出现错误java.lang.ClassNotFoundException:org.slf4j.LoggerFactory

尝试执行jar时出现错误java.lang.ClassNotFoundException:org.slf4j.LoggerFactory,java,logging,slf4j,slf4j-api,Java,Logging,Slf4j,Slf4j Api,当我尝试执行java-jar app.jar时,我得到了以下结果: Exception in thread "JavaFX Application Thread" Exception in thread "main" java.lang.NoClassDefFoundError: org/slf4j/LoggerFactory at tao.qaflash.GUI.<clinit>(GUI.java:14) at java.lang.Class.forName0(N

当我尝试执行java-jar app.jar时,我得到了以下结果:

Exception in thread "JavaFX Application Thread" Exception in thread "main" 
java.lang.NoClassDefFoundError: org/slf4j/LoggerFactory
    at tao.qaflash.GUI.<clinit>(GUI.java:14)
    at java.lang.Class.forName0(Native Method)
    at java.lang.Class.forName(Class.java:348)
    at com.sun.javafx.application.LauncherImpl.lambda$launchApplicationWithArgs$156(LauncherImpl.java:352)
    at com.sun.javafx.application.PlatformImpl.lambda$runAndWait$175(PlatformImpl.java:326)
    at com.sun.javafx.application.PlatformImpl.lambda$null$173(PlatformImpl.java:295)
    at java.security.AccessController.doPrivileged(Native Method)
    at com.sun.javafx.application.PlatformImpl.lambda$runLater$174(PlatformImpl.java:294)
    at com.sun.glass.ui.InvokeLaterDispatcher$Future.run(InvokeLaterDispatcher.java:95)
    at com.sun.glass.ui.win.WinApplication._runLoop(Native Method)
    at com.sun.glass.ui.win.WinApplication.lambda$null$148(WinApplication.java:191)
    at java.lang.Thread.run(Thread.java:745)
Caused by: java.lang.ClassNotFoundException: org.slf4j.LoggerFactory
    at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    ... 12 more
java.lang.reflect.InvocationTargetException
    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:498)
    at sun.launcher.LauncherHelper$FXHelper.main(LauncherHelper.java:767)
Caused by: java.lang.NullPointerException
    at com.sun.javafx.application.LauncherImpl.launchApplicationWithArgs(LauncherImpl.java:383)
    at com.sun.javafx.application.LauncherImpl.launchApplication(LauncherImpl.java:328)
    ... 5 more

非常感谢您的帮助。

很简单:您在尝试执行JAR文件时使用的类路径不包含所需的sl4j记录器库

这就是一切。这是而不是关于您的构建设置-它是关于在命令行上运行
java
时使用的设置


请参阅以进一步阅读。

似乎您在运行时也需要slf4j。查看一下

我已经解压缩了在dist文件夹中创建的zip文件,它可以工作:)因为在lib文件夹中有sl4j api。

但是依赖项中已经有了:编译'org.slf4j:slf4j api:1.7.21',我仍然得到了错误…我试图从命令行设置类路径,也得到了相同的结果错误:java-jar app.jar-classpath C:\Users\Administrator\.gradle\caches\modules-2\files-2.1\org.slf4j\slf4j-api\1.7.21\139535a69a4239db087de9bab0bee568bf8e0b70\slf4j-api-1.7.21.jar这就是api jar。如果slf4j也有一些实现jar,我不会感到惊讶。换句话说:一个罐子可能不行!我很欣赏这种快速回归:-)对于其他阅读者来说:您是否在编译file.jar时使用相同的JDK版本?(作为第一步,我建议使用相同的JDK,甚至不是相同版本的JRE。)只是为了排除可能的错误源。这修复了我的问题,但出现了相同的症状:)使用此示例行指向任何JVM:“c:\Program Files\Java\jdk1.8.0\u 121\bin\Java.exe”-jar d:\Path\to\Your\File.jar
dependencies {
  compile 'net.sf.staf:jstaf:3.4.4'

  // SLF4J API module which will be used for logging
  compile 'org.slf4j:slf4j-api:1.7.21'

  // Log4J2 logging framework including the binding module to slf4j
  compile 'org.apache.logging.log4j:log4j-slf4j-impl:2.5'
  compile 'org.apache.logging.log4j:log4j-api:2.5'
  compile 'org.apache.logging.log4j:log4j-core:2.5'

  testCompile 'junit:junit:4.12'
  testCompile "org.testfx:testfx-core:4.0.+"
  testCompile "org.testfx:testfx-junit:4.0.+"
}