Public Key Retrieval is not allowed

“Public Key Retrieval is not allowed”错误通常出现在MySQL数据库连接过程中,当客户端尝试从服务器检索RSA公钥进行身份验证时未得到允许。这个错误可能由多种原因引起,以下是对该错误的详细分析以及相应的解决方案:

错误原因分析

  1. 禁用SSL/TLS协议

    • 当SSL/TLS协议被禁用时,客户端和服务器之间的通信不再加密。如果客户端需要公钥来解密服务器端的加密密码,就会因为缺少公钥而导致此错误。
  2. 用户登录状态变更

    • 在新建数据库用户、用户首次登录、数据库的用户名或密码发生改变后登录,以及服务器端调用FLUSH PRIVILEGES指令刷新服务器缓存等情况下,客户端可能无法获取到服务器的公钥,从而引发此错误。
  3. Java系统属性或安全策略限制

    • 在使用Java进行连接时,如果jdk.tls.allowLegacyHelloMessages或jsse.enableSNIExtension系统属性被设置为不允许公钥检索,或者应用程序的安全策略配置阻止了公钥自动检索功能,也可能导致此错误。
  4. 服务器配置问题

    • 如果服务器端配置了不支持公钥自动检索或者服务器证书链不完整,客户端可能无法验证服务器公钥,从而导致此错误。

解决方案

  1. 启用SSL/TLS协议

    • 如果条件允许,最好的解决方法是启用SSL/TLS协议,确保客户端和服务器之间的通信加密。这可以通过在数据库连接字符串中设置相关参数来实现(如useSSL=true,但具体参数可能因数据库类型和版本而异)。
  2. 允许客户端检索公钥

    • 如果必须禁用SSL/TLS协议,可以通过在数据库连接字符串中添加allowPublicKeyRetrieval=true参数来允许客户端从服务器检索公钥。例如,对于Java的JDBC连接,可以修改连接字符串为:“jdbc:mysql://hostname:port/database?allowPublicKeyRetrieval=true&useSSL=false”。
  3. 使用CLI客户端制造登录缓存

    • 如果必须禁用SSL/TLS协议,并且出现了公钥检索错误,可以尝试使用CLI客户端登录一次MySQL数据库,以制造登录缓存。这有助于在某些情况下解决公钥检索问题。
  4. 调整Java系统属性或安全策略

    • 检查并更新相关Java系统属性设置,确保允许公钥检索。同时,调整应用程序的安全策略,允许公钥自动检索和/或SNI扩展。
  5. 检查服务器配置

    • 确保服务器端配置正确,提供完整的证书链,并且支持公钥自动检索。如果服务器证书存在问题,请确保服务器已安装正确的证书,并且客户端信任该证书颁发机构。
  6. 更改身份验证方法

    • 如果控制MySQL用户的创建方式,可以考虑使用mysql_native_password身份验证插件来避免这个错误。这可以通过登录到MySQL数据库,并使用ALTER USER命令来更改用户的身份验证方法来实现。同时,也可以考虑修改MySQL配置文件,使默认身份验证插件为mysql_native_password。

综上所述,“Public Key Retrieval is not allowed”错误可能由多种原因引起,但通常可以通过启用SSL/TLS协议、允许客户端检索公钥、调整Java系统属性或安全策略、检查服务器配置以及更改身份验证方法等方法来解决。如果以上方法均无法解决问题,建议联系数据库管理员或寻求专业的技术支持。

实战:

添加allowPublicKeyRetrieval=true&useSSL=false 正常使用

<think>我们正在解决“publickeyretrievalisnotallowed”错误。这个错误通常在使用JDBC连接MySQL时出现,尤其是在使用SSL连接或某些安全设置时。原因可能是客户端尝试从服务器获取公钥,但服务器配置或客户端连接参数禁止此操作。解决方案通常包括:1.在连接字符串中添加`allowPublicKeyRetrieval=true`参数(注意安全风险)。2.使用正确的SSL配置(如果使用SSL)。3.提供服务器公钥的本地副本。由于引用内容中并没有直接相关的信息,我们将基于常见知识提供解决方案。注意:允许公钥检索可能存在安全风险,因此仅建议在安全的环境中使用(如测试环境),生产环境应使用更安全的方式(如SSL证书)。下面我们将详细说明解决方案。</think>### 解决“public key retrieval is not allowed”错误 该错误通常出现在Java应用连接MySQL 8.0+数据库时,主要由于新版本的安全机制变更。以下是完整的解决方案: #### 1. **添加连接参数(推荐临时方案)** 在JDBC连接URL中添加参数: ```url jdbc:mysql://yourhost:3306/dbname?allowPublicKeyRetrieval=true&useSSL=false ``` - `allowPublicKeyRetrieval=true`:允许客户端获取公钥 - `useSSL=false`:禁用SSL(仅测试环境使用)[^1] > ⚠️ **注意**:生产环境应启用SSL并配置证书 #### 2. **永久解决方案** ```url jdbc:mysql://yourhost:3306/dbname?allowPublicKeyRetrieval=true&useSSL=true&trustCertificateKeyStoreUrl=file:path/to/keystore ``` 1. 从服务器获取公钥: ```bash mysql -u root -p --ssl-mode=DISABLED -e "SHOW STATUS LIKE 'Caching_sha2_password_public_key'" > public_key.pem ``` 2. 在客户端配置信任库: ```bash keytool -importcert -alias mysqlServer -file public_key.pem -keystore truststore.jks ``` #### 3. **服务器端配置(需DBA权限)** 修改MySQL配置`my.cnf`: ```ini [mysqld] default_authentication_plugin = mysql_native_password # 回退旧认证 caching_sha2_password_public_key_path = /path/to/public_key.pem ``` 重启服务生效[^4] #### 4. **客户端驱动升级** 确保使用最新JDBC驱动: ```xml <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.33+</version> </dependency> ``` #### 错误原因分析 MySQL 8.0默认使用`caching_sha2_password`插件,其公钥传输机制受安全策略限制: $$ \text{客户端} \xrightarrow{\text{未授权公钥请求}} \text{MySQL服务器} \Rightarrow \text{拒绝连接} $$ 当客户端无法通过SSL安全获取公钥时触发此错误[^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

杰哥技术分享

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值