Spring Boot 启动错误排查教程之找不到或无法加载主类的三种解决方案

 更新时间:2026年02月09日 10:32:42   作者:柚子科技  
这篇文章主要介绍了Spring Boot 启动错误排查实战找不到或无法加载主类的三种解决方案,文章详细介绍了三个排查步骤:确认主启动类是否规范、检查IDE的运行配置以及清理构建缓存并重新编译,需要的朋友可以参考下

写在前面:这篇文章适合谁?

这篇文章主要写给 正在开发或学习 Spring Boot 的同学,尤其是刚接触 Spring Boot、在课程设计或毕业设计阶段频繁导入项目的人

我最近在一台 Windows 11 + JDK 8 / JDK 17 的开发环境中,多次遇到 Spring Boot 项目启动时报错:

错误: 找不到或无法加载主类 xxx.Application

这个问题在IDE 中看似简单,但实际排查时非常浪费时间。在完整解决并复盘之后,我把关键排查点整理成一篇文章,希望能帮你少走弯路。

一、问题现象与错误本质

常见报错信息如下:

Error: Could not find or load main class com.example.demo.DemoApplication
Caused by: java.lang.ClassNotFoundException

从 JVM 的角度来看,这个错误只有一个核心含义:

启动时指定的主类,在当前 classpath 中不存在。

但“为什么不存在”,才是我们真正要解决的问题。

二、第一步:确认 Spring Boot 主启动类是否规范

这是最基础、也是最容易被忽略的一步。

1️⃣ 主启动类必须满足的条件

请确认你的启动类同时满足以下要求:

  • 位于 src/main/java 目录下
  • 包名与实际目录结构一致
  • 包含 @SpringBootApplication 注解
  • 包含标准的 main 方法

示例代码如下:

package com.example.demo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
/**
 * @author LLL
 * @since 2026
 */
@SpringBootApplication
public class DemoApplication {
    public static void main(String[] args) {
        SpringApplication.run(DemoApplication.class, args);
    }
}

⚠️ 真实踩坑点
我曾在重构包名后,只改了文件夹路径,却忘了同步修改 package 声明,IDE 不报红,但启动直接失败。

三、第二步:检查 IDE 的运行配置(高频问题)

在我的经验中,至少一半的“找不到主类”问题,都出在运行配置上,而不是代码本身

2.1 IntelliJ IDEA 中的排查方式

依次检查:

  1. 点击右上角运行配置
  2. 打开 Run / Debug Configurations
  3. 查看当前 Spring Boot 配置项

重点关注两个地方:

  • Main class
    • 是否是当前项目真实存在的 Application
  • Module
    • 是否选择了正确的模块(多模块项目尤其容易出错)

👉 推荐做法
直接删除原有运行配置,然后:

  • 右键点击 Application
  • 选择 Run

让 IDEA 自动生成配置,成功率最高。

2.2 Eclipse 中的排查方式

在 Eclipse 中,这个问题更常见,建议直接使用“重建思路”:

  • 打开 Run Configurations
  • 删除旧的 Java ApplicationSpring Boot App
  • 重新右键主启动类 → Run As

四、第三步:清理构建缓存并重新编译

当代码和运行配置都没问题,但错误依旧存在时,十有八九是构建缓存出了问题

3.1 Eclipse:使用 Clean 功能

Project → Clean → Clean all projects

这个操作会清理旧的 .class 文件和构建缓存,对 Eclipse 用户非常关键。

3.2 IntelliJ IDEA + Maven 项目

我个人更推荐直接从 Maven 下手:

mvn clean package

重点观察:

  • target/classes 目录下
  • 是否真的生成了 DemoApplication.class

如果 .class 文件都没生成,JVM 自然找不到主类。

五、容易被忽略但很致命的细节

下面这些问题我都真实踩过坑

  • 项目 JDK 与 IDE JDK 不一致
  • 多模块项目,启动模块选错
  • pom.xml 编译失败但未注意控制台日志
  • 使用了不兼容的 JDK 版本(例如低版本 Spring Boot + 高版本 JDK)

建议:
遇到问题时,先看一遍完整控制台日志,而不是只盯着最后一行报错。

回到问题本身

在文章开头我们提到,这个错误的本质是:

JVM 在 classpath 中找不到你指定的主类。

只要你围绕以下三个点去排查:

  1. 主启动类是否真实存在
  2. IDE 是否指向了正确的类
  3. 编译结果是否真的生成

这个问题几乎都能解决。

结语

我长期整理 Spring Boot / Java 毕业设计 / 课程设计常见问题,并将踩坑过程写成系列文章,主要面向计算机专业在校生和初学者

到此这篇关于Spring Boot 启动错误排查实战:找不到或无法加载主类的三种解决方案的文章就介绍到这了,更多相关springboot启动错误找不到或无法加载主类内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java8 日期、时间操作代码

    Java8 日期、时间操作代码

    在Java8之前,日期时间API一直被开发者诟病,包括:java.util.Date是可变类型,SimpleDateFormat非线程安全等问题。故此,Java8引入了一套全新的日期时间处理API,新的API基于ISO标准日历系统
    2021-09-09
  • Kotlin中常见的List使用示例教程

    Kotlin中常见的List使用示例教程

    filter 就像其本意一样,可以通过 filter 对 Kotlin list 进行过滤,本文重点给大家介绍Kotlin中常见的List使用,感兴趣的朋友一起看看吧
    2023-11-11
  • 详解Spring中Spel表达式和el表达式的区别

    详解Spring中Spel表达式和el表达式的区别

    在 Java 开发中,表达式语言是一种强大的工具,而SpEL 表达式与EL 表达式是我们常常遇到两种表达式语言,下面我们就来看看它们的具体使用与区别吧
    2023-07-07
  • SpringBoot+RustFS 实现文件切片极速上传的实例代码

    SpringBoot+RustFS 实现文件切片极速上传的实例代码

    本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考价值,感兴趣的可以了解一下
    2025-09-09
  • Java代码注释规范详解

    Java代码注释规范详解

    代码附有注释对程序开发者来说非常重要,随着技术的发展,在项目开发过程中,必须要求程序员写好代码注释,这样有利于代码后续的编写和使用。下面给大家分享java代码注释的规范,需要的朋友参考下
    2016-02-02
  • 注解@CrossOrigin解决跨域的问题

    注解@CrossOrigin解决跨域的问题

    这篇文章主要介绍了注解@CrossOrigin解决跨域的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09
  • Java统计字符串中字符出现次数的方法示例

    Java统计字符串中字符出现次数的方法示例

    这篇文章主要介绍了Java统计字符串中字符出现次数的方法,涉及Java针对字符串的遍历、查找、计算等相关操作技巧,需要的朋友可以参考下
    2017-12-12
  • 深入理解Java对象的序列化与反序列化的应用

    深入理解Java对象的序列化与反序列化的应用

    本篇文章是对Java中对象的序列化与反序列化进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • DoytoQuery 聚合查询方案示例详解

    DoytoQuery 聚合查询方案示例详解

    这篇文章主要为大家介绍了DoytoQuery 聚合查询方案示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • java字符串相似度算法

    java字符串相似度算法

    这篇文章主要介绍了java字符串相似度算法,是Java实现比较典型的算法,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-02-02

最新评论