Pab*_*abi 8 java eclipse maven log4j2
我在我的java应用程序中使用log4j 2.3.我通过maven添加了依赖项.
在eclipse中运行程序时一切正常,但是当我用maven打包并尝试运行jar时,我得到以下错误:
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache logging/log4j/LogManager
at main.myclass.<clinit>(myclass.java:11)
Caused by: java.lang.ClassNotFoundException: org.apache.logging.log4j.LogManager
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
Run Code Online (Sandbox Code Playgroud)
为什么从jar运行它时无法找到类?
添加log4j 1.2
也不起作用.该程序在eclipse中正常运行,因此不应缺少依赖项.
Gar*_*rry 15
从命令行运行应用程序jar时,依赖jar在运行时不可用.您需要将这两个插件中的任何一个包含到pom.xml中,以便在运行时使用您的依赖项.
使用:maven-shade-plugin
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-shade-plugin</artifactId>
<version>2.4.1</version>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>shade</goal>
</goals>
<configuration>
<transformers>
<transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
<mainClass>org.sonatype.haven.HavenCli</mainClass>
</transformer>
</transformers>
</configuration>
</execution>
</executions>
</plugin>
Run Code Online (Sandbox Code Playgroud)
使用:Maven的依赖关系的插件
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<version>2.8</version>
<executions>
<execution>
<id>copy-dependencies</id>
<phase>package</phase>
<goals>
<goal>copy-dependencies</goal>
</goals>
<configuration>
<outputDirectory>${project.build.directory}/lib</outputDirectory>
</configuration>
</execution>
</executions>
</plugin>
Run Code Online (Sandbox Code Playgroud)
当你执行mvn package
它时,它将生成uber jar /或将依赖项复制到outputDirectory.我更喜欢maven-shade-plugin生成一个jar将所有依赖项.
归档时间: |
|
查看次数: |
18090 次 |
最近记录: |