SpringBoot启动失败Application run failed的问题分析及解决办法

 更新时间:2026年01月20日 08:51:09   作者:二哈喇子!  
文章主要介绍了SpringBoot启动失败的问题分析和解决办法,包括XML文件格式错误、数据库名称错误以及MyBatis扫描路径问题的排查和修复步骤,感兴趣的朋友跟随小编一起看看吧

这个异常的问题源比较多,得具体问题具体分析,得看下面那些报错什么意思,不能直接去网上找解决办法

前言

Navicat 能看本地数据库和服务器数据库,具体是哪里的数据库要看清楚,最好cmd命令show databases看一下

项目场景一:Application run failed

提示:SpringBoot服务启动的时候报错:
这个问题遇到好多次了,一直没能记录下来,今天又碰到了

Error starting ApplicationContext. To display the conditions report re-run your application with 'debug' enabled.
ERROR 1572 --- [  restartedMain] o.s.boot.SpringApplication               : Application run failed

🧨 错误总览

下面是错误报告我用回车隔开方便查看

Error creating bean with name 'userAction': 
Unsatisfied dependency expressed through field 'userService'; 
nested exception is ... 
Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: 
Error creating bean with name 'userServiceImpl': 
nested exception is ... 
Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: 
Error creating bean with name 'userMapper' defined in file [...] 
nested exception is ... 
Caused by: org.springframework.beans.factory.BeanCreationException: 
Error creating bean with name 'sqlSessionFactory' ... 
nested exception is ... 
Caused by: org.springframework.beans.BeanInstantiationException: 
Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]... 
nested exception is org.springframework.core.NestedIOException: 
Failed to parse mapping resource: 'file [.../mapper/UserMapper.xml]'... 
nested exception is org.apache.ibatis.builder.BuilderException: 
Error creating document instance. Cause: org.xml.sax.SAXParseException; lineNumber: 1; columnNumber: 36;
在 XML 声明中的编码伪属性前面必须有空格。

🔍 错误根本原因

UserMapper.xml 文件的第一行 XML 声明格式不正确。

具体报错是:

在 XML 声明中的编码伪属性前面必须有空格。

这个错误通常出现在 XML 文件的最开始一行,也就是:

<?xml version="1.0" encoding="UTF-8"?><!-- 正确写法 -->

但你的文件可能写成了:

<?xml version="1.0"encoding="UTF-8"?> <!-- ❌ 错误:没有空格 -->

或者:

<?xml version="1.0" encoding="UTF-8" standalone="yes" ?>

其中某个地方少了空格、引号没闭合、语法不对等。

✅ 解决方案

✅ 第一步:检查UserMapper.xml的第一行

打开文件:

E:\桌面\springbootdemo\target\classes\mapper\UserMapper.xml

(注意:这个路径是你编译后的路径,实际修改应该去源码目录下的 XML 文件)

找到类似这一行:

<?xml version="1.0"encoding="UTF-8"?>

改成:

<?xml version="1.0" encoding="UTF-8"?>

确保:

  • versionencoding 属性之间有空格
  • encoding="UTF-8" 写法正确
  • 没有多余的字符或拼写错误

✅ 第二步:验证 XML 是否语法正确

你可以将整个 XML 文件粘贴到在线 XML 验证工具中,例如:

  • https://www.xmlvalidation.com/

它会告诉你哪一行哪个位置出错了。

✅ 第三步:重新构建项目

修改完 XML 后,在命令行执行:

mvn clean install
# 或者
gradle clean build

然后重启 Spring Boot 应用。

🧪 示例修复前 vs 修复后

❌ 错误示例:

<?xml version="1.0"encoding="UTF-8"?>
<mapper namespace="cn.edu.neu.springbootdemo.mapper.UserMapper">
    ...
</mapper>

✅ 正确示例:

<?xml version="1.0" encoding="UTF-8"?>
<mapper namespace="cn.edu.neu.springbootdemo.mapper.UserMapper">
    ...
</mapper>

📝 小贴士

问题建议
XML 报错定位难使用 IDE 打开 XML 文件,一般会有语法高亮提示
编码格式混乱确保文件保存为 UTF-8 格式
中文乱码在 XML 头部声明 encoding=“UTF-8” 并保持文件编码一致
Mapper 路径未扫描到检查是否配置了 MyBatis 的 mapper-locations

✅ 总结

步骤内容
1️⃣定位到 UserMapper.xml 文件
2️⃣修改 XML 声明头,补上空格,如:<?xml version="1.0" encoding="UTF-8"?>
3️⃣清理并重新构建项目
4️⃣重启应用

场景分析二:Application run failed

Error starting ApplicationContext. To display the conditions report re-run your application with 'debug' enabled.
2022-10-14 13:15:21.461 ERROR 12548 --- [           
    main] o.s.boot.SpringApplication               
    : Application run failed

原因分析

往下看原因:Caused by:

下面是错误报告我用回车隔开方便检查

Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: 
Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/baomidou/mybatisplus/spring/boot/starter/MybatisPlusAutoConfiguration.class]: 
Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: 
Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: 
Factory method 'sqlSessionFactory' threw exception; 
nested exception is com.baomidou.mybatisplus.exceptions.MybatisPlusException: 
Error: GlobalConfigUtils setMetaData Fail !  
Cause:java.sql.SQLSyntaxErrorException: Unknown database 'jiakao'

重点在最后一句,他说我这个错误是:GlobalConfigUtils setMetaData失败!

原因:java.sql SQLSyntaxErrorException:未知数据库“jiakao”

解决办法

上面的错误说数据库名字不对

打开数据库可视化工具一看,是数据库名字打错了

果然数据库名字一改后,立马跑通

总结:

重要的不是问题解决了,重要的是解决问题的过程
还有error才会影响程序的运行,warning警告不用管
根据错误的提示去想,为什么找不到这个bean/class?通过这个错误一步步去跟踪,找到根本的原因,这是积累知识的过程
等以后这种问题发现地慢慢的多起来,慢慢地积累起来,积累的经验越多越好
英语很重要,不仅仅是处理问题的时候、出错的时候、分析问题的时候都是英文

到此这篇关于SpringBoot启动失败Application run failed的解决办法的文章就介绍到这了,更多相关SpringBoot启动失败Application run failed内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java的几种文件拷贝方式示例详解

    Java的几种文件拷贝方式示例详解

    在Java编程中文件操作是常见且重要的任务之一,其中文件拷贝是一种基本操作,这篇文章主要给大家介绍了关于Java几种文件拷贝方式的相关资料,文中给出了详细的代码示例,需要的朋友可以参考下
    2024-08-08
  • Spring boot 应用实现动态刷新配置详解

    Spring boot 应用实现动态刷新配置详解

    这篇文章主要介绍了spring boot 配置动态刷新实现详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2021-09-09
  • 构建SpringBoot+MyBatis+Freemarker的项目详解

    构建SpringBoot+MyBatis+Freemarker的项目详解

    在本篇内容里小编给大家整理的是关于构建SpringBoot+MyBatis+Freemarker的项目的具体步骤以及实例代码,需要的朋友们参考下。
    2019-06-06
  • Java实现控制台输出两点间距离

    Java实现控制台输出两点间距离

    这篇文章主要介绍了Java实现控制台输出两点间距离,涉及了部分编程坐标的问题,具有一定参考价值,需要的朋友可以了解下
    2017-09-09
  • RabbitMQ之消息的可靠性方案详解

    RabbitMQ之消息的可靠性方案详解

    这篇文章主要介绍了RabbitMQ之消息的可靠性方案详解,MQ 消息数据完整的链路为:从 Producer 发送消息到 RabbitMQ 服务器中,再由 Broker 服务的 Exchange 根据 Routing_Key 路由到指定的 Queue 队列中,最后投送到消费者中完成消费,需要的朋友可以参考下
    2023-08-08
  • 详解Java关于JDK中时间日期的API

    详解Java关于JDK中时间日期的API

    这篇文章主要介绍了详解Java关于JDK中时间日期的API,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-09-09
  • SpringBoot使用Spring Security实现登录注销功能

    SpringBoot使用Spring Security实现登录注销功能

    这篇文章主要介绍了SpringBoot使用Spring Security实现登录注销功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2020-09-09
  • java实现折半排序算法

    java实现折半排序算法

    折半插入排序法,又称二分插入排序法,是直接插入排序法的改良版,也需要执行i-1趟插入,不同之处在于,第i趟插入,先找出第i+1个元素应该插入的的位置,假定前i个数据是已经处于有序状态。
    2015-04-04
  • Java之OutputStreamWriter流案例详解

    Java之OutputStreamWriter流案例详解

    这篇文章主要介绍了Java之OutputStreamWriter流案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • Java实现发送短信验证码+redis限制发送的次数功能

    Java实现发送短信验证码+redis限制发送的次数功能

    这篇文章主要介绍了Java实现发送短信验证码+redis限制发送的次数,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-04-04

最新评论