解决 java -jar 报错:xxx.jar 中没有主清单属性

举报
Damon小智 发表于 2024/11/26 22:39:28 2024/11/26
【摘要】 本文详细解析了在使用java-jar命令运行Java应用程序时,遇到“没有主清单属性”错误的原因和解决方案。该错误是由于JAR文件缺少Main-Class属性,导致Java虚拟机无法定位程序的入口点。为解决此问题,文章指导如何在pom.xml中正确配置Maven插件,特别是spring-boot-maven-plugin,确保生成的JAR文件包含必要的启动信息。通过调整部分的配置,重新构建项目,并

问题复现

在使用 java -jar xxx.jar 命令运行 Java 应用程序时,遇到了以下错误:

xxx.jar 中没有主清单属性

001.png

这个错误表示 JAR 文件缺少必要的启动信息,Java 虚拟机无法找到应用程序的入口点。本文将介绍该错误的原因以及如何通过修改 pom.xml 文件来解决。


错误原因

当你使用 java -jar 命令运行一个 JAR 文件时,Java 虚拟机会在该 JAR 的 META-INF/MANIFEST.MF 文件中查找 Main-Class 属性,以确定应用程序的入口点。如果该属性缺失,或者指定的主类不存在,就会导致上述错误。


解决方法

要解决这个问题,需要在项目的 pom.xml 文件中配置 Maven 插件,以正确生成包含 Main-Class 属性的可执行 JAR 文件。

步骤一:在 pom.xml 中添加或修改 <build> 配置

在你的 pom.xml 文件中,找到或添加 <build> 部分。

002.png

然后修补上以下内容:

<build>
    <plugins>
        <!-- Maven Compiler Plugin -->
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>3.8.1</version>
            <configuration>
                <source>1.8</source>
                <target>1.8</target>
                <encoding>UTF-8</encoding>
            </configuration>
        </plugin>

        <!-- Spring Boot Maven Plugin -->
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
            <version>${spring-boot.version}</version>
            <configuration>
                <mainClass>xxx.xxx.xxx.xxxApplication</mainClass>
                <skip>false</skip>
            </configuration>
            <executions>
                <execution>
                    <id>repackage</id>
                    <goals>
                        <goal>repackage</goal>
                    </goals>
                </execution>
            </executions>
        </plugin>
    </plugins>
</build>

配置说明:

  • Maven Compiler Plugin:指定了 Java 源代码和目标版本,以及编码格式。
  • Spring Boot Maven Plugin
    • <mainClass>:指定应用程序的主类,必须包含 main 方法。请将 xxx.xxx.rxxxdc.xxxApplication 替换为你实际的主类路径。
    • <skip>false</skip>:确保插件不会被跳过,默认情况下可以省略该配置。
    • <executions>:指定在构建过程中执行 repackage 目标,重新打包 JAR 文件。

步骤二:重新构建项目

在项目根目录下,运行以下命令:

mvn clean package

这将清理项目并重新打包,生成的 JAR 文件通常位于 target 目录下,名称类似于 xxx.jar

也可以在 IDEAMaven 菜单里右键操作。

先运行 clean

003.png

再运行 package

004.png


步骤三:运行生成的 JAR 文件

使用以下命令运行应用程序:

java -jar target/xxx.jar

如果配置正确,应用程序应该能够正常启动,不再出现 “没有主清单属性” 的错误。

005.png


注意事项

  • 确认主类存在且路径正确:确保你的主类(例如 xxxApplication)存在,并且位于指定的包路径下(例如 xxx.xxx.xxx)。
  • 版本一致性spring-boot-maven-plugin 的版本应与 Spring Boot 的版本一致,通常使用 ${spring-boot.version} 引用。
  • 避免插件被跳过:确保 <skip>false</skip>,避免插件被跳过。
  • 重新打包:确保 <executions></executions>标签及内部的repackage属性存在。

结论

通过在 pom.xml 文件中正确配置 Maven 插件,可以解决 java -jar 命令运行时出现的 “没有主清单属性” 的错误。关键是确保生成的 JAR 文件包含正确的 Main-Class 属性,以及所有必要的依赖项。

希望本篇文章能够帮助你解决问题,顺利运行你的 Java 应用程序。

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。