我正在尝试从命令行运行我的应用程序 - 我执行以下操作 - 使用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没有下载依赖并将其放入相关位置?我可能从项目设置中遗漏了什么?
由于
答案 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但检查再分配条款。