首页 > 解决方案 > 来自 Maven 的具有依赖关系的可执行 jar 文件

问题描述

Maven jar 插件 - Intellij jar 文件中的 java.lang.NoClassDefFoundError

我正在尝试从 maven 项目中 jar 类但未找到类错误。

我已将此添加到 pom 文件中

           <plugin>
                <!-- Build an executable JAR -->
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-jar-plugin</artifactId>
                <version>3.1.0</version>
                <configuration>
                    <archive>
                        <manifest>
                            <addClasspath>true</addClasspath>
                            <classpathPrefix>lib/</classpathPrefix>
                            <mainClass>training.avro.KafkaAvroJavaProducerV1Demo</mainClass>
                        </manifest>
                    </archive>
                </configuration>
            </plugin>

我做了一个 Maven 安装然后运行

java -jar target/kafka-avro-v1-1.0-SNAPSHOT.jar

这是我的项目的名称,当我从 intellij 运行时,这个主类运行良好。

但是后来我从 jar 中运行了这个错误

Error: A JNI error has occurred, please check your installation and try again
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/kafka/clients/producer/Producer
        at java.lang.Class.getDeclaredMethods0(Native Method)
        at java.lang.Class.privateGetDeclaredMethods(Class.java:2701)
        at java.lang.Class.privateGetMethodRecursive(Class.java:3048)
        at java.lang.Class.getMethod0(Class.java:3018)
        at java.lang.Class.getMethod(Class.java:1784)
        at sun.launcher.LauncherHelper.validateMainClass(LauncherHelper.java:544)
        at sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:526)
Caused by: java.lang.ClassNotFoundException: org.apache.kafka.clients.producer.Producer
        at java.net.URLClassLoader.findClass(URLClassLoader.java:382)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
        at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:349)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
        ... 7 more

标签: javamavenjarexecutable-jar

解决方案


推荐阅读