在类路径上找不到log4j - Maven

时间:2014-10-11 19:30:32

标签: java maven log4j

我正在尝试从命令行运行我的应用程序 - 我执行以下操作 - 使用mvn clean verify构建应用程序,生成一个jar,以正常方式运行jar java -jar name.jar

我在我的pom.xml中配置了log4j,如下所示;

<dependency>
    <groupId>log4j</groupId>
    <artifactId>log4j</artifactId>
    <version>1.2.17</version>
</dependency>

我已设置应用程序以创建清单,如下所示;

<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<version>2.4</version>
<configuration>
    <archive>
        <manifest>
            <addClasspath>true</addClasspath>
            <mainClass>com.me.main.Main</mainClass>
        </manifest>
    </archive>
</configuration>

然而,当我运行jar时,我不断收到以下异常 -

Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/log4j/Logger
    at com.me.main.Main.<clinit>(Main.java:23)
Caused by: java.lang.ClassNotFoundException: org.apache.log4j.Logger
    at java.net.URLClassLoader$1.run(URLClassLoader.java:372)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:360)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    ... 1 more

为什么maven没有下载依赖并将其放入相关位置?我可能从项目设置中遗漏了什么?

由于

1 个答案:

答案 0 :(得分:2)

Maven只是构建您的JAR并在构建时管理依赖项。毕竟它是一个构建工具。如果你的工作是在运行时处理依赖关系。

我认为你有两种选择。

一个是清单中的Class-Path设置。我从来没有用过它,但我要做的事情就是:

Class-Path: log4j-1.2.7.jar

只要log4j-1.2.7.jar放在它旁边,java -jar你的.jar就应该工作。正如我所说,我从来没有尝试过,不知道语法是否正确,不要相信我。

如果你想这样做,你可能会考虑准备一个拉链组件,否则人们会疯狂地试图弄清楚如何调用你的应用程序。

另一种选择是使用maven-shade-plugin。会是这样的:

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-shade-plugin</artifactId>
    <executions>
        <execution>
            <phase>package</phase>
            <goals>
                <goal>shade</goal>
            </goals>
            <configuration>
                <transformers>
                    <transformer 
                        implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
                        <mainClass>com.me.main.Main</mainClass>
                    </transformer>
                </transformers>
            </configuration>
        </execution>
    </executions>
</plugin>

你将获得内部所有内容的大型JAR。

我个人认为这是一种更好的选择。但要非常小心许可证。 IANAL但检查再分配条款。