Public Key Retrieval is not allowed

26 篇文章 0 订阅
11 篇文章 0 订阅

Public Key Retrieval is not allowed

最近使用 JDBC 连接 MySQL 频繁出现如下报错:
java.sql.SQLNonTransientConnectionException: Public Key Retrieval is not allowe

Public Key Retrieval is not allowed
这段代码是一个 Java 异常错误信息,其中包含了以下关键信息:

  • 错误类型:java.sql.SQLNonTransientConnectionException
  • 错误描述:Public Key Retrieval is not allowed.
  • 抛出异常的位置:com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:825)

根据异常信息提示,这是 MySQL 数据库连接时出现的问题。
更具体地说,可能是由于连接字符串 URL 中缺少 allowPublicKeyRetrieval=true 参数导致的。

为了解决该异常,可以尝试采取以下几种方法:

  1. 修改 MySQL 数据库连接字符串 URL,在末尾追加 ?allowPublicKeyRetrieval=true 参数。如:
    String url = "jdbc:mysql://localhost:3306/mydatabase?allowPublicKeyRetrieval=true&useSSL=false";
    
  2. 如果使用的是 Java 8 及以上版本,可以将 SSL 模式设置为 false ,即在 JDBC 驱动程序中通过添加一个额外属性来关闭 SSL
    String url = "jdbc:mysql://localhost:3306/mydatabase?sslMode=DISABLED";
    
    此时可以不需要 allowPublicKeyRetrieval=true 参数选项。

但其根本原因是 MySQL 使用了 Innovation 版本,而驱动版本不一致导致的

<!-- 低版本驱动 -->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.33</version>
</dependency>
<!-- 高版本驱动 此版本为 Innovation 版本驱动-->
<dependency>
    <groupId>com.mysql</groupId>
    <artifactId>mysql-connector-j</artifactId>
    <version>8.4.0</version>
</dependency>

升级 MySQL 驱动 Innovation 版本后修改 MySQL 数据库连接字符串 URL如下:

  • xm文件
    jdbc:mysql://localhost:3306/db?allowPublicKeyRetrieval=true&amp;useUnicode=true&amp;createDatabaseIfNotExist=true&amp;characterEncoding=UTF8&amp;useSSL=false&amp;serverTimeZone=Asia/Shanghai&amp;sslMode=DISABLED
    
  • 非xml文件
    jdbc:mysql://localhost:3306/db?allowPublicKeyRetrieval=true&useUnicode=true&createDatabaseIfNotExist=true&characterEncoding=UTF8&useSSL=false&serverTimeZone=Asia/Shanghai&sslMode=DISABLED
    
  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Public Key Retrieval is not allowed是一个错误消息,通常在使用DBeaver等数据库客户端连接数据库时出现。这个错误消息表明,连接设置不允许公共密钥检索。这可能是由于数据库配置或网络设置导致的。要解决这个问题,有几种可能的方法可以尝试。 首先,可以检查数据库的配置。使用翻译软件翻译整个网页,找到数据库配置中的"AllowPublicKeyRetrieval"选项。确认该选项的值是否为true。如果不是,可以将其更改为true,以允许公共密钥检索。这可以通过编辑数据库的配置文件或在数据库管理工具中进行设置来实现。 另外,可以检查网络设置。有时,网络中的防火墙或代理服务器可能会阻止公共密钥检索。确保网络设置允许数据库客户端与数据库服务器进行通信,并允许公共密钥检索。如果有必要,可以与网络管理员联系以获取更多帮助。 此外,还可以参考关于JDBC连接数据库时出现"Public Key Retrieval is not allowed"错误的指南。这些指南可能提供了更具体的步骤和解决方案,以解决这个问题。 总结起来,要解决"Public Key Retrieval is not allowed"错误,可以通过检查数据库配置、调整网络设置,并参考相关指南来尝试解决问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [DBeaver Public Key Retrieval is not allowed解决](https://blog.csdn.net/Azure_xw/article/details/126254898)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [DBeaver连接时报错:Public Key Retrieval is not allowed Public Key Retrieval is not allowed](https://blog.csdn.net/qq_42971035/article/details/120247453)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

李昊哲小课

桃李不言下自成蹊

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值