Maven Classpath Log4J NoClassDefFoundError

时间:2014-10-04 23:56:38

标签: java maven jar log4j classpath

您好我正在尝试创建一个JAR,它有多个可以运行的Main类。 我正在使用Maven构建,我的pom.xml看起来像这样:

http://maven.apache.org/xsd/maven-4.0.0.xsd“>     4.0.0     ch.uzh.ifi.ce     CombinatorialAuction     1.0     组合拍卖     

    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>3.1</version>
            <configuration>
                <source>1.8</source>
                <target>1.8</target>
            </configuration>
        </plugin>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-jar-plugin</artifactId>
            <version>2.5</version>

        </plugin>

    </plugins>
</build>
<properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <sonar.language>java</sonar.language>
    <sonar.jdbc.url>
        jdbc:h2:tcp://localhost:9092/sonar
    </sonar.jdbc.url>
    <sonar.host.url>
        http://localhost:9000
    </sonar.host.url>
</properties>

<dependencies>



    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-core</artifactId>
        <version>2.0.2</version>
    </dependency>

     <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-api</artifactId>
        <version>2.0.2</version>
    </dependency>
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-log4j12</artifactId>
        <version>1.7.7</version>
    </dependency>
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-api</artifactId>
        <version>1.7.7</version>
    </dependency>

</dependencies>

然后我尝试使用以下命令运行Main类

java -cp CombinatorialAuction-1.0.jar ch.uzh.ifi.ce.cca.bneexecution.SingleBNERunner

但是我得到以下异常,这表明依赖项似乎不起作用。

java.lang.NoClassDefFoundError: org/slf4j/LoggerFactory

非常感谢任何帮助。

2 个答案:

答案 0 :(得分:0)

我认为你的pom.xml缺乏对SLF4J API的依赖:

<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-api</artifactId>
    <version>1.7.7</version>
</dependency>

有点奇怪,slf4j-log4j12不会带来这种依赖。

答案 1 :(得分:0)

所以我明白了。 问题是依赖关系没有与jar一起打包......(我的愚蠢)。我使用了shade插件来创建一个带有依赖项的jar。