当前位置: 首页 > news >正文

Public Key Retrieval is not allowed

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
    
http://www.lryc.cn/news/346806.html

相关文章:

  • iphone进入恢复模式怎么退出?分享2种退出办法!
  • Leetcode 107:二叉树的层次遍历II
  • LNMP一键安装包
  • [机器学习-05] Scikit-Learn机器学习工具包进阶指南:协方差估计和交叉分解功能实战【2024最新】
  • 多线程的情况下 AopContext.currentProxy()切面代理失效问题
  • https://是怎么实现的?
  • Linux无root配置Node,安装nvm
  • 蛋糕店做配送小程序的作用是什么
  • 重写muduo之TcpServer
  • 腾讯云服务器之ssh远程连接登录及转发映射端口实现内网穿透(实现服务器访问本地电脑端口)
  • oracle 9i 行头带有scn的表
  • MySql#MySql安装和配置
  • WEB前端复习——HTML
  • Java医院绩效管理应用系统源码java+ maven+ avue 公立医院绩效考核管理系统源码 支持二开
  • 湖南知识付费系统开发公司,教育机构如何提高转化率?有哪些途径?
  • Goland GC
  • 【SRC实战】合成类小游戏外挂漏洞
  • 【牛客】SQL206 获取每个部门中当前员工薪水最高的相关信息
  • 2024年最新趋势跨境电商平台开发需了解的新技术
  • Mac 查看jdk版本
  • C++面向对象学习笔记五
  • 7-Zip 的使用技巧
  • 德国储能项目锂电池储能集装箱突发火灾:安全挑战再引关注
  • FFmpeg常用API与示例(二)—— 解封装与转封装
  • 笨方法自学python(一)
  • centos7.9升级4.19内核
  • 神经网络模型与前向传播函数
  • 跟我学C++中级篇——内联补遗
  • SLAM 面试题
  • csapp proxy lab part 1