数据库连接报错问题

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

结合你之前的报错(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 驱动兼容性极好,不需要复杂的公钥交换过程,因此能直接解决连接被拒绝的问题。

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

相关推荐
一条泥憨鱼1 小时前
【Redis】数据类型和常用命令
java·数据库·redis·后端·缓存
爱喝水的鱼丶2 小时前
SAP-ABAP:SAP视图开发入门:四类标准视图的适用场景与创建步骤详解
服务器·数据库·性能优化·sap·abap
大白要努力!3 小时前
MySQL 8.0 + Navicat 完整操作指南
数据库·mysql
云絮.4 小时前
数据库操作
数据库·mysql·算法·oracle
小小工匠4 小时前
Redis 缓存替换策略:8 种淘汰策略与 LRU 实现剖析
数据库·redis·缓存
小小龙学IT6 小时前
Go 泛型深度解析:从设计哲学到工程实践
服务器·数据库·golang
天行健,君子而铎6 小时前
2026年通用行业数据分类分级产品排名——聚焦成本低、全链路覆盖与高性能计算的优质选型
大数据·数据库·人工智能
Tong Z6 小时前
Mysql DDL中的ALGORITHM
数据库·mysql