2014-07-22 1 views
0

У меня есть проект maven, в котором я использую slf4j.log4j. Когда я запускаю свой проект в среде IDE, он работает нормально и показывает журнал на консоли.Создание проекта с log4j с использованием maven

Но когда я упаковать проект в банке и запустить его я получаю

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, чтобы зависимости были включены в банку. Я прочитал много ответов, но я все больше смущен, чем больше читаю. Расскажите, какие изменения мне нужно внести в файл pom.xml.

ответ