jar运行报错nomainmanifestattribute原因分析及解决
jar运行报错no main manifest attribute
部署到服务器,满怀期待地执行那条经典命令:
免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈
ja va -jar test-0.0.1-SNAPSHOT.jar
结果迎面而来的却是一盆冷水:
no main manifest attribute, in test-0.0.1-SNAPSHOT.jar
别慌,这个问题在Ja va开发中相当常见,本质上就是系统在跟你“要人”——它不知道应该从哪个“入口”开始执行你的程序。
原因
问题的核心直截了当:找不到主类。
Ja va程序打包成可执行的jar包,有一个关键约定:必须在MANIFEST.MF文件中明确指定Main-Class项。这就像是给jar包一张“说明书”,告诉ja va -jar命令:“嘿,请从我这个类开始运行。”
我们来做个现场勘查。把报错的test-0.0.1-SNAPSHOT.jar解压,看看里面究竟少了什么。

找到META-INF目录下的MANIFEST.MF文件,打开一看,真相大白。


看到了吗?文件里空空如也,或者缺少了关键的Main-Class行。而一个正常的、能直接运行的jar包,它的清单文件应该是这样的:

对比之下,问题一目了然。
解决
既然找到了病根,接下来就是对症下药。对于使用Ma ven管理的Spring Boot项目,修复起来其实很有章法。
第一步,检查基础配置。先确认你的pom.xml里是否已经声明了打包方式为jar。如果缺少,赶紧加上:
jar
第二步,也是关键一步,配置打包插件。在pom.xml的 -> 部分,加入Spring Boot Ma ven插件,并指定好主类:
org.springframework.boot spring-boot-ma ven-plugin 2.6.0 com.xtool.manager.MainDemo XTool nothing nothing repackage
这里有几个配置点需要划下重点:
- mainClass:这里必须填写你项目启动类的完整包路径。如果你的项目不是可执行应用,自然不需要配置这一项。
- finalName:这决定了最终生成的jar包名字。比如这里配置
XToolXTool.jar。如果不指定,Ma ven会默认使用artifactId和version来拼接文件名。 - includes 标签:这个配置有点意思。如果你希望生成的“胖jar包”不包含任何第三方依赖,保留这个配置即可。反之,如果你想打一个包含所有依赖的、可以直接用
ja va -jar运行的独立包,那就需要删除整个标签及其内容。...
第三步,执行打包。配置好后,在IntelliJ IDEA右侧的Ma ven工具窗口中,找到Lifecycle下的package,点击它,静静等待打包完成。

打包成功的jar包,会乖乖地躺在项目的target目录下。

如果按照以上步骤操作后问题依旧,不妨换个思路,尝试直接用IDEA内置的功能来打包。具体方法可以参考另一篇详细的指南:idea 项目代码打包为jar包。
总结
总的来说,“no main manifest attribute”这个错误就像一个守门员,它提醒我们打包时别忘了指定程序的起点。通过正确配置Ma ven插件,明确主类路径,就能轻松跨过这道坎。希望以上的分析和步骤能为大家提供一个清晰的解决思路。
您可能感兴趣的文章:
- 项目打包成jar后包无法读取src/main/resources下文件的解决
- IDEA打包jar-解决找不到或无法加载主类 main的问题
- ja va打包成jar并执行jar包中指定的main方法
热门专题
热门推荐
红米Note 11 Pro系统升级,为何坚持要求连接Wi-Fi? 当红米Note 11 Pro收到MIUI或澎湃OS的系统更新推送时,官方总会明确提示:整个过程请在Wi-Fi网络环境下完成。这项要求并非随意设定,而是基于清晰的技术与体验考量。一次完整的系统升级包,其大小通常在2GB至4GB之间。如果
小米13 Ultra的NFC功能深度解析:它如何重新定义“全场景智能交互”? 在旗舰手机领域,NFC功能看似已成为标配,但体验却千差万别。小米13 Ultra所搭载的全功能NFC方案,在“全能”与“好用”两个维度上树立了新的标杆。它不仅无缝集成了公交卡模拟、门禁卡复制、数字车钥匙等核心生活服务,更全
嵌入式消毒柜电源插座安装指南:隐蔽式布局提升安全与美观 在规划嵌入式消毒柜的安装方案时,电源插座的布局方式直接影响到最终的整体效果与安全性。正确的做法是避免插座外露,采用隐蔽式安装。根据国家《住宅厨房设计规范》及主流厨电品牌的安装标准,推荐将插座预留在消毒柜后方或侧方的墙体内部,安装高度宜控制在距地
是的,魔音(Beats)耳机充电状态一目了然,指示灯明确显示 当你为Beats头戴式耳机充电时,如何判断它是否已经充满?答案就藏在机身自带的五段式LED电量指示灯里。在充电过程中,这排指示灯会持续闪烁,实时反馈充电进度。一旦所有五个指示灯全部转为稳定常亮、不再闪烁,即代表电池已完全充满。整个充电周期
博朗剃须刀型号全解析:从编码规则到选购技巧的终极指南 面对博朗剃须刀复杂的字母数字组合感到困惑?实际上,其型号命名体系逻辑严谨,是用户选购的核心依据。简单来说,型号首位的数字(1、3、5、7、9)直接代表产品系列,数字越大,通常意味着技术越先进、功能越全面、定位越高端。例如,顶级的9系旗舰机型普遍搭





