【问题标题】:SLF4J .NoClassDefFoundError when running by command line on jar file [duplicate]SLF4J .NoClassDefFoundError 在 jar 文件上通过命令行运行时[重复]
【发布时间】:2022-01-01 19:39:11
【问题描述】:

如果我在 mvn clean install(全部使用 GUI)后使用 Intellij 按钮启动它,我有一个运行良好的应用程序。

我尝试使用命令行运行生成的 jar 文件:

java -jar myJar.jar

但我无法停止遇到这些错误:

java -jar .\myJar-SNAPSHOT.jar
Exception in thread "main" java.lang.NoClassDefFoundError: org/slf4j/LoggerFactory
    at data.SecretProvider.<clinit>(SecretProvider.java:14)

同样,如果我使用 Intellij 运行应用程序,则不会出现错误并且日志可以正常工作。

我认为这是我将 jar 打包到 pom.xml 中的方式,但我对此一无所知。 这是 pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<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>org.bouji</groupId>
<artifactId>myjar</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>jar</packaging>

<properties>
    <maven.compiler.source>11</maven.compiler.source>
    <maven.compiler.target>11</maven.compiler.target>
</properties>

<repositories>
    <repository>
        <id>dv8tion</id>
        <name>m2-dv8tion</name>
        <url>https://m2.dv8tion.net/releases</url>
    </repository>
</repositories>

<dependencies>
    <dependency>
        <groupId>net.dv8tion</groupId>
        <artifactId>JDA</artifactId>
        <version>5.0.0-alpha.3</version>
    </dependency>
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-api</artifactId>
        <version>2.7</version>
    </dependency>
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-core</artifactId>
        <version>2.7</version>
    </dependency>
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-slf4j-impl</artifactId>
        <version>2.7</version>
    </dependency>
    <dependency>
        <groupId>com.sedmelluq</groupId>
        <artifactId>lavaplayer</artifactId>
        <version>1.3.77</version>
    </dependency>
    <dependency>
        <groupId>com.amazonaws</groupId>
        <artifactId>aws-java-sdk</artifactId>
        <version>1.11.163</version>
    </dependency>
    <dependency>
        <groupId>org.jooq</groupId>
        <artifactId>jool</artifactId>
        <version>0.9.14</version>
    </dependency>
    <dependency>
        <groupId>org.junit.jupiter</groupId>
        <artifactId>junit-jupiter-engine</artifactId>
        <version>5.8.1</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>org.mockito</groupId>
        <artifactId>mockito-core</artifactId>
        <version>2.21.0</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>com.amazonaws</groupId>
        <artifactId>aws-java-sdk</artifactId>
        <version>1.11.960</version>
    </dependency>
</dependencies>

<build>
    <plugins>
        <plugin>
            <!-- Build an executable JAR -->
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-jar-plugin</artifactId>
            <version>3.1.0</version>
            <configuration>
                <archive>
                    <manifest>
                        <mainClass>CatBot</mainClass>
                    </manifest>
                </archive>
            </configuration>
        </plugin>
    </plugins>
</build>

尝试在这里阅读类似的问题,但它似乎总是特定于错误/ide。

【问题讨论】:

  • 使用-jar时,你的jar必须在meta信息中包含classpath。
  • 构建一个胖罐确实可以解决问题。需要看看这是否不是一个坏习惯,因为 jar 用于在服务器上部署。

标签: java maven intellij-idea classpath pom.xml


【解决方案1】:

在 jar 的 MANIFEST 文件中,必须有应用程序运行所需的依赖项。确保您拥有它们。

另外-jar 不包括文件本身以外的类路径。您可以尝试运行:

java -cp <path>myJar-SNAPSHOT.jar;<path to missing> <your main class>

【讨论】:

  • 有很多依赖项,所以我使用@Karthikeyan 的答案来构建一个胖罐子。
猜你喜欢
  • 2021-09-28
  • 1970-01-01
  • 2018-04-26
  • 1970-01-01
  • 2012-07-09
  • 1970-01-01
  • 1970-01-01
  • 2011-08-12
  • 2017-02-19
相关资源
最近更新 更多