SpringBoot啟動(dòng)報(bào)錯(cuò)找不到或無法加載主類的三種解決方案
前言
這篇文章主要寫給 正在開發(fā)或?qū)W習(xí) Spring Boot 的同學(xué),尤其是剛接觸 Spring Boot、在課程設(shè)計(jì)或畢業(yè)設(shè)計(jì)階段頻繁導(dǎo)入項(xiàng)目的人。
我最近在一臺(tái) Windows 11 + JDK 8 / JDK 17 的開發(fā)環(huán)境中,多次遇到 Spring Boot 項(xiàng)目啟動(dòng)時(shí)報(bào)錯(cuò):
錯(cuò)誤: 找不到或無法加載主類 xxx.Application
這個(gè)問題在IDE 中看似簡單,但實(shí)際排查時(shí)非常浪費(fèi)時(shí)間。在完整解決并復(fù)盤之后,我把關(guān)鍵排查點(diǎn)整理成一篇文章,希望能幫你少走彎路。
一、問題現(xiàn)象與錯(cuò)誤本質(zhì)
常見報(bào)錯(cuò)信息如下:
Error: Could not find or load main class com.example.demo.DemoApplication
Caused by: java.lang.ClassNotFoundException
從 JVM 的角度來看,這個(gè)錯(cuò)誤只有一個(gè)核心含義:
啟動(dòng)時(shí)指定的主類,在當(dāng)前 classpath 中不存在。
但“為什么不存在”,才是我們真正要解決的問題。
二、第一步:確認(rèn) Spring Boot 主啟動(dòng)類是否規(guī)范
這是最基礎(chǔ)、也是最容易被忽略的一步。
主啟動(dòng)類必須滿足的條件
請確認(rèn)你的啟動(dòng)類同時(shí)滿足以下要求:
- 位于
src/main/java目錄下 - 包名與實(shí)際目錄結(jié)構(gòu)一致
- 包含
@SpringBootApplication注解 - 包含標(biāo)準(zhǔn)的
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);
}
}
真實(shí)踩坑點(diǎn):
我曾在重構(gòu)包名后,只改了文件夾路徑,卻忘了同步修改 package 聲明,IDE 不報(bào)紅,但啟動(dòng)直接失敗。
三、第二步:檢查 IDE 的運(yùn)行配置(高頻問題)
在我的經(jīng)驗(yàn)中,至少一半的“找不到主類”問題,都出在運(yùn)行配置上,而不是代碼本身。
2.1 IntelliJ IDEA 中的排查方式
依次檢查:
- 點(diǎn)擊右上角運(yùn)行配置
- 打開 Run / Debug Configurations
- 查看當(dāng)前 Spring Boot 配置項(xiàng)
重點(diǎn)關(guān)注兩個(gè)地方:
- Main class:是否是當(dāng)前項(xiàng)目真實(shí)存在的
Application類 - Module:是否選擇了正確的模塊(多模塊項(xiàng)目尤其容易出錯(cuò))
推薦做法
直接刪除原有運(yùn)行配置,然后:
- 右鍵點(diǎn)擊
Application類 - 選擇
Run
讓 IDEA 自動(dòng)生成配置,成功率最高。
2.2 Eclipse 中的排查方式
在 Eclipse 中,這個(gè)問題更常見,建議直接使用“重建思路”:
- 打開
Run Configurations - 刪除舊的
Java Application或Spring Boot App - 重新右鍵主啟動(dòng)類 →
Run As
四、第三步:清理構(gòu)建緩存并重新編譯
當(dāng)代碼和運(yùn)行配置都沒問題,但錯(cuò)誤依舊存在時(shí),十有八九是構(gòu)建緩存出了問題。
3.1 Eclipse:使用 Clean 功能
Project → Clean → Clean all projects
這個(gè)操作會(huì)清理舊的 .class 文件和構(gòu)建緩存,對 Eclipse 用戶非常關(guān)鍵。
3.2 IntelliJ IDEA + Maven 項(xiàng)目
我個(gè)人更推薦直接從 Maven 下手:
mvn clean package
重點(diǎn)觀察:
target/classes目錄下- 是否真的生成了
DemoApplication.class
如果 .class 文件都沒生成,JVM 自然找不到主類。
五、容易被忽略但很致命的細(xì)節(jié)
下面這些問題我都真實(shí)踩過坑:
- 項(xiàng)目 JDK 與 IDE JDK 不一致
- 多模塊項(xiàng)目,啟動(dòng)模塊選錯(cuò)
pom.xml編譯失敗但未注意控制臺(tái)日志- 使用了不兼容的 JDK 版本(例如低版本 Spring Boot + 高版本 JDK)
建議:遇到問題時(shí),先看一遍完整控制臺(tái)日志,而不是只盯著最后一行報(bào)錯(cuò)。
回到問題本身
在文章開頭我們提到,這個(gè)錯(cuò)誤的本質(zhì)是:
JVM 在 classpath 中找不到你指定的主類。
只要你圍繞以下三個(gè)點(diǎn)去排查:
- 主啟動(dòng)類是否真實(shí)存在
- IDE 是否指向了正確的類
- 編譯結(jié)果是否真的生成
這個(gè)問題幾乎都能解決。
以上就是SpringBoot啟動(dòng)報(bào)錯(cuò)找不到或無法加載主類的三種解決方案的詳細(xì)內(nèi)容,更多關(guān)于SpringBoot啟動(dòng)報(bào)錯(cuò)解決的資料請關(guān)注腳本之家其它相關(guān)文章!
- SpringBoot項(xiàng)目啟動(dòng)報(bào)錯(cuò)"找不到或無法加載主類"的解決方法
- SpringBoot項(xiàng)目啟動(dòng)錯(cuò)誤:找不到或無法加載主類的幾種解決方法
- 解決springboot運(yùn)行出現(xiàn)錯(cuò)誤:找不到或無法加載主類com.xxxx.xxxx.Application問題
- SpringBoot項(xiàng)目啟動(dòng)錯(cuò)誤:找不到或無法加載主類的三種解決方法
- springboot項(xiàng)目啟動(dòng)類錯(cuò)誤(找不到或無法加載主類 com.**Application)
- idea啟動(dòng)springboot報(bào)錯(cuò): 找不到或無法加載主類問題
- 解決SpringBoot運(yùn)行報(bào)錯(cuò):找不到或無法加載主類的問題
- 解決springboot錯(cuò)誤:找不到或無法加載主類(配置編碼或者M(jìn)aven)
相關(guān)文章
Mybatis如何使用ognl表達(dá)式實(shí)現(xiàn)動(dòng)態(tài)sql
這篇文章主要介紹了Mybatis使用ognl表達(dá)式實(shí)現(xiàn)動(dòng)態(tài)sql的操作,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06
淺談java object對象在heap中的結(jié)構(gòu)
本文主要介紹了淺談java object對象在heap中的結(jié)構(gòu),感興趣的同學(xué),可以參考下。2021-06-06

