你提供的日志信息非常关键。这展示了应用程序的启动过程。
结合你之前的报错(Public Key Retrieval is not allowed)和这个启动日志,我们可以得出一个明确的结论:
🛑 现状分析
你的应用启动失败了。
虽然日志最后显示了 Tomcat started on port(s): 28089 和 Started 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;
第四步:重启应用
- 回到你的 IDEA 或命令行,按
Ctrl+C停止正在运行的 Java 程序。 - 重新启动项目。
- 刷新浏览器页面。
❓ 为什么这样做有效?
- 报错原因 :MySQL 8 默认的认证方式(
caching_sha2_password)在某些配置下需要获取公钥,而 Java 驱动默认禁止此操作。 - 解决原理 :
mysql_native_password是 MySQL 5.7 及以前版本使用的旧认证方式,它与 Java 的 JDBC 驱动兼容性极好,不需要复杂的公钥交换过程,因此能直接解决连接被拒绝的问题。
注意:如果你不确定自己的数据库密码是多少,或者执行上述命令报错,请告诉我,我们可以尝试其他方法(如修改配置文件)。