【发布时间】:2015-04-02 20:10:36
【问题描述】:
我将我的项目从 eclipse 移到了 netbeans,现在当我在构建后尝试运行 .jar 文件时收到 Exception in thread "main" java.lang.NoClassDefFoundError: org/slf4j/LoggerFactory 错误。该程序运行良好
这是我的类路径中的内容:
slf4j-api-1.7.11.jar
slf4j-ext-1.7.11.jar
log4j-1.2.17.jar
这是我的记录器:
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class Log {
public static final Logger logger = LoggerFactory.getLogger(Log.class);
public Log(){
}
}
log4j.properties:
# Root logger option
log4j.rootLogger=INFO, file
# Direct log messages to a log file
log4j.appender.file=org.apache.log4j.RollingFileAppender
#Redirect to Tomcat logs folder
#log4j.appender.file.File=${catalina.home}/logs/logging.log
log4j.appender.file.File=C:\\Log.log
log4j.appender.file.MaxFileSize=10MB
log4j.appender.file.MaxBackupIndex=10
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n
当我想记录一些东西时我会调用什么(这就是它爆炸并抛出错误的地方):
Log.logger.info("");
例外:
Picked up _JAVA_OPTIONS: -Djava.net.preferIPv4Stack=true
Exception in thread "main" java.lang.NoClassDefFoundError: org/slf4j/LoggerFactory
at com.xxx.xxxx.Log.<clinit>(Log.java:8)
at com.xxx.xxxx.MainGui.PrintHeaderForLog(MainGui.java:319)
at com.xxx.xxxx.MainGui.<init>(MainGui.java:69)
at com.xxx.xxxx.MainGui.<clinit>(MainGui.java:48)
Caused by: java.lang.ClassNotFoundException: org.slf4j.LoggerFactory
at java.net.URLClassLoader$1.run(Unknown Source)
at java.net.URLClassLoader$1.run(Unknown Source)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(Unknown Source)
at java.lang.ClassLoader.loadClass(Unknown Source)
at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
at java.lang.ClassLoader.loadClass(Unknown Source)
... 4 more
【问题讨论】:
-
看起来这是一个tomcat web应用?每个 slf4j jar 具体部署在哪里?您能否编辑您的问题以包含您收到的此异常的完整堆栈跟踪?
-
它是一个简单的 java 程序,我只是将它用作记录器。当我用 eclipse 构建它时它正在工作。我已经添加了例外。
-
另外,我的 log4j.properties 文件位于 src 目录中。
-
我在您的 log4j.properties 中看到了 catalina 引用,并认为它可能是 stackoverflow.com/q/24342963/13317。但看起来你的类路径中缺少 slf4j-api。