java.sql.SQLNonTransientConnectionException: Public Key Retrieval is not allowed

 更新时间:2025年05月22日 11:04:16   作者:断墨先生  
本文主要介绍了java.sql.SQLNonTransientConnectionException: Public Key Retrieval is not allowed错误的问题解决,下面就来介绍几种解决方法,感兴趣的可以了解一下

在使用 MySQL 8.0 或更高版本时,可能会遇到以下错误:java.sql.SQLNonTransientConnectionException: Public Key Retrieval is not allowed
这是因为 MySQL 8.0 默认启用了 caching_sha2_password 插件,而 JDBC 驱动默认不允许检索公钥。以下是几种常见的解决方法:

解决方案一:修改数据库连接字符串

在 JDBC 连接 URL 中添加 allowPublicKeyRetrieval=true 参数:

jdbc:mysql://localhost:3306/your_database?useSSL=false&allowPublicKeyRetrieval=true&serverTimezone=UTC
  • allowPublicKeyRetrieval=true:允许检索公钥。
  • useSSL=false:禁用 SSL,视需求而定。

解决方案二:修改 MySQL 用户认证插件

ALTER USER 'your_user'@'your_host' IDENTIFIED WITH mysql_native_password BY 'your_password';

解决方案三:更新 MySQL JDBC 驱动

确保使用最新版的 MySQL JDBC 驱动,以避免与 MySQL 8.0 的认证方式不兼容
Maven 示例:

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.30</version>
</dependency>

总结

  • 如果不想修改认证插件,使用 allowPublicKeyRetrieval=true 解决问题。
  • 可以修改用户认证插件为 mysql_native_password,或更新 JDBC 驱动。

到此这篇关于java.sql.SQLNonTransientConnectionException: Public Key Retrieval is not allowed的文章就介绍到这了,更多相关java.sql.SQLNonTransientConnectionException内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

相关文章

  • Mybatis框架之模板方法模式(Template Method Pattern)的实现

    Mybatis框架之模板方法模式(Template Method Pattern)的实现

    MyBatis中使用了模板方法模式来控制SQL语句的执行流程,本文主要介绍了Mybatis框架之模板方法模式(Template Method Pattern)的实现,需要的朋友们下面随着小编来一起学习学习吧
    2024-11-11
  • Maven生成及安装jar包到本地仓库的方法

    Maven生成及安装jar包到本地仓库的方法

    这篇文章主要介绍了Maven生成及安装jar包到本地仓库的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-10-10
  • 解决mybatis-plus使用jdk8的LocalDateTime 查询时报错的方法

    解决mybatis-plus使用jdk8的LocalDateTime 查询时报错的方法

    这篇文章主要介绍了解决mybatis-plus使用jdk8的LocalDateTime 查询时报错的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • Mybatis-Plus 全局配置无效的解决方案

    Mybatis-Plus 全局配置无效的解决方案

    这篇文章主要介绍了Mybatis-Plus 全局配置无效的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-01-01
  • Java调用.dll文件的方法

    Java调用.dll文件的方法

    因为项目的需求,要在JAVA项目中调用Windows的Dll(动态链接库)文件,之前用Jni调用过C写的Dll文件,比较麻烦,这里不多说,网上也有很多这方面的文档。在网上找到一个开源的组件JNative,使用后感觉比较方便
    2013-04-04
  • 如何使用@Slf4j和logback-spring.xml搭建日志框架

    如何使用@Slf4j和logback-spring.xml搭建日志框架

    这篇文章主要介绍了如何使用@Slf4j和logback-spring.xml搭建日志框架问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-06-06
  • SpringBoot实现多文件上传的详细示例代码

    SpringBoot实现多文件上传的详细示例代码

    文件上传中并没有什么太多的知识点,下面这篇文章主要给大家介绍了关于SpringBoot实现多文件上传的详细示例,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-03-03
  • SpringSecurit盐值加密的密码验证以及强密码验证过程

    SpringSecurit盐值加密的密码验证以及强密码验证过程

    在密码加密过程中,盐值的使用可以增强密码的安全性,如果忘记存储盐值,将无法验证密码,强密码应包含数字、字母和特殊字符,长度应在8到30位之间,以提高账户安全
    2023-03-03
  • mybatis项目实现动态表名的三种方法

    mybatis项目实现动态表名的三种方法

    有时在开发过程中java代码中的表名和数据库的表名并不是一致的,此时我们就需要动态的设置表名,本文主要介绍了mybatis项目实现动态表名的三种方法,具有一定的参考价值,感兴趣的可以了解一下
    2024-01-01
  • Java 读取PDF中的文本和图片的方法

    Java 读取PDF中的文本和图片的方法

    本文将介绍通过Java程序来读取PDF文档中的文本和图片的方法。分别调用方法extractText()和extractImages()来读取,需要的朋友可以参考下
    2019-07-07

最新评论