2014-07-22 44 views
0

我有一个使用slf4j.log4j的maven项目。当我在IDE中运行我的项目时,它运行良好,并在控制台上显示日志。使用maven构建一个使用log4j的项目

但是,当我收拾该项目作为一个jar和运行它,我得到

Exception in thread "main" java.lang.NoClassDefFoundError: org/slf4j/LoggerFactory 
     at com.hl7.common.StartListeners.<clinit>(StartListeners.java:8) 
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) 
     ... 1 more 

这里是我的pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> 
    <modelVersion>4.0.0</modelVersion> 
    <groupId>com.hl7</groupId> 
    <artifactId>appointments-web</artifactId> 
    <version>0.0.1-SNAPSHOT</version> 

    <properties> 

    </properties> 
    <dependencies> 

     <!-- Logging --> 
     <dependency> 
      <groupId>org.slf4j</groupId> 
      <artifactId>slf4j-api</artifactId> 
      <version>1.7.5</version> 
     </dependency> 
     <dependency> 
      <groupId>org.slf4j</groupId> 
      <artifactId>slf4j-log4j12</artifactId> 
      <scope>runtime</scope> 
      <version>1.7.5</version> 
     </dependency> 

    </dependencies> 
</project> 

这里是我的log4j.properties在src/main/resources

文件
log4j.rootLogger=DEBUG, consoleAppender, fileAppender 

log4j.appender.consoleAppender=org.apache.log4j.ConsoleAppender 
log4j.appender.consoleAppender.layout=org.apache.log4j.PatternLayout 
log4j.appender.consoleAppender.layout.ConversionPattern=[%t] %-5p %c %x - %m%n 

log4j.appender.fileAppender=org.apache.log4j.RollingFileAppender 
log4j.appender.fileAppender.layout=org.apache.log4j.PatternLayout 
log4j.appender.fileAppender.layout.ConversionPattern=[%t] %-5p %c %x - %m%n 
log4j.appender.fileAppender.File=HL7.log 

这里是我如何使用记录器 -

package com.hl7.common; 

import org.slf4j.Logger; 
import org.slf4j.LoggerFactory; 

public class StartListeners { 

    private static final Logger logger = LoggerFactory.getLogger(StartListeners.class); 

    public static void main(String[] args){ 
     ListenersManager.start(); 
     logger.info("Listeners started....................."); 
     return; 
    } 

如何使用maven构建我的项目,以便将依赖项包含在jar中。我读了很多答案,但我读得越多,我越感到困惑。请告诉我需要对pom.xml文件进行哪些更改。

回答