数据库连接报错问题

你提供的日志信息非常关键。这展示了应用程序的启动过程

结合你之前的报错(Public Key Retrieval is not allowed)和这个启动日志,我们可以得出一个明确的结论:

🛑 现状分析

你的应用启动失败了。

虽然日志最后显示了 Tomcat started on port(s): 28089Started NewBeeMallApplication,但这通常只是 Spring Boot 容器本身的启动日志。根据你之前的报错,当浏览器尝试访问首页(IndexController)并加载分类数据时,程序会因为数据库连接失败而抛出异常,导致网页无法正常显示。

🔍 关键证据:驱动版本

在你的启动日志(长命令行部分)中,有一段非常重要的信息:

com\mysql\mysql-connector-j\8.0.31\...

这说明你使用的是 MySQL 8.x 的驱动程序 。正如之前分析的,MySQL 8 默认使用 caching_sha2_password 认证插件,而你的数据库用户(很可能是 root)目前的配置与该插件不兼容。


💡 最终解决方案

你需要在 MySQL 数据库端 执行 SQL 命令来解决问题。

请按照以下步骤操作:

第一步:登录 MySQL

打开命令行(CMD)或数据库管理工具(如 Navicat、DBeaver),使用你的用户名(通常是 root)和密码登录 MySQL。

第二步:执行修改命令

请将下面的 SQL 命令中的 your_password 替换成你实际的数据库密码,然后执行:

复制代码
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'your_password';
  • 解释 :这条命令的作用是强制 root 用户使用旧版的、兼容性更好的密码验证方式,而不是 MySQL 8 默认的、容易出问题的新方式。
第三步:刷新权限

执行完上面的命令后,紧接着执行:

复制代码
FLUSH PRIVILEGES;
第四步:重启应用
  1. 回到你的 IDEA 或命令行,按 Ctrl+C 停止正在运行的 Java 程序。
  2. 重新启动项目。
  3. 刷新浏览器页面。

❓ 为什么这样做有效?

  • 报错原因 :MySQL 8 默认的认证方式(caching_sha2_password)在某些配置下需要获取公钥,而 Java 驱动默认禁止此操作。
  • 解决原理mysql_native_password 是 MySQL 5.7 及以前版本使用的旧认证方式,它与 Java 的 JDBC 驱动兼容性极好,不需要复杂的公钥交换过程,因此能直接解决连接被拒绝的问题。

注意:如果你不确定自己的数据库密码是多少,或者执行上述命令报错,请告诉我,我们可以尝试其他方法(如修改配置文件)。

相关推荐
先吃饱再说21 小时前
存储的进化:从 MySQL 到浏览器缓存,数据到底住在哪?
数据库
Nturmoils21 小时前
字段太多看不全,ksql 的展开模式和输出控制怎么用
数据库·后端
Databend1 天前
Agent 轨迹分析与归因的数据工程实践
大数据·数据库·agent
这个DBA有点耶1 天前
SQL改写进阶:标量子查询的“隐形代价”与消除实战
数据库·mysql·架构
smallyoung1 天前
数据库乐观锁深度解析:MySQL、PostgreSQL 实战 + Spring Boot 集成指南
数据库·mysql·postgresql
parade岁月1 天前
MySQL JOIN解析:朴实无华但食之有味
数据库·后端
用户3169353811831 天前
MySQL服务无法启动问题解决全记录
数据库
vivo互联网技术1 天前
从 10 分钟到 1 秒:ES 深度分页任意跳页的三轮优化实战
服务器·数据库·redis·elasticsearch·深度分页
倔强的石头_2 天前
《Kingbase护城河》——猎捕慢查询:执行计划的微观解析与索引调优实战
数据库
SelectDB2 天前
Apache Doris Python UDF:让 SQL 直接调用 Python 生态,支撑 Agent 时代复杂业务逻辑
大数据·数据库·python