解决 Java 中 the Public Keys in Reply and Keystore Don‘t Match 错误

2024-02-07 15:04

本文主要是介绍解决 Java 中 the Public Keys in Reply and Keystore Don‘t Match 错误,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本篇文章讨论 keytool error: java.lang.Exception: Public keys in reply and keystore don’t match 错误。 它还强调了导致此错误的可能原因。

此外,我们将了解可用于修复此错误的不同解决方案。


keytool error: java.lang.Exception: Public keys in reply and keystore don’t match 的错误描述、原因及可能的解决方案

我们将尝试访问托管在端口 443 的 Web 服务。服务提供商共享三个证书:ABCD.cer、CCA_Certificate.cer 和 CA_Certificate.cer。

我们需要通过创建 SSL 通信的表单链将它们全部添加到 KeyStore 中。 下面按顺序给出了我们在本文中遵循的步骤。

  • keytool -keystore npci_keystore.jks -genkey -alias npci_client
  • keytool -import -keystore npci_keystore.jks -file CA_Certificate.cer -alias CARoot
  • keytool -import -keystore npci_keystore.jks -file CCA_Certificate.cer -alias CCARoot
  • keytool -import -keystore npci_keystore.jks -file ABCD.cer -alias npci_client

此时,我们收到错误消息,提示 keytool error: java.lang.Exception: Public keys in reply and keystore don’t match。 这个错误到底是怎么回事? 为什么我们会遇到这个问题?

我们遇到此问题的原因有多种,如下所示:

  1. 当我们尝试使用不同的密钥对生成证书时,我们会收到此错误。
  2. 如果我们在导入证书和创建 JKS 存储时使用相同的别名,则会出现此错误。
  3. 有时,以错误的顺序安装证书也会导致此错误。
  4. 如果链中缺少根 CA 的证书,我们也会解决此问题。

现在的重点是如何消灭它。 让我们在下一节中看看。


解决 Public Keys in Reply and Keystore Don’t Match 错误

在我们的场景中,我们使用的链接指导我们如何为服务器创建 SSL KeyStore,这不是我们想要实现的目标。 我们所做的是从创建新的密钥对开始。

接下来,我们向 KeyStore 添加一个受信任的证书,向 KeyStore 添加另一个受信任的证书,然后尝试为我们的密钥对导入服务器的 SSL 证书。

此时,我们失败了,因为生成的 SSL 证书适用于完全不同的密钥对。 我们拥有的三项证书包括:

  1. Web 服务的 SSL 证书
  2. 签署 SSL 证书的 CA 证书
  3. 签署 CA 的根证书

现在,我们必须将信任锚添加到我们的 TrustStore 中。 默认情况下,它是 ${JAVA_HOME}/jre/lib/security/cacerts,结果是我们的客户端接受 Web 服务的 SSL 证书。

请记住,在 SSL 握手期间,SSL 服务器将整个链(不包括根证书)发送到客户端。 因此,我们必须将根证书添加到我们的信任库中,如下所示。

keytool -import -keystore ${JAVA_HOME}/jre/lib/security/cacerts -file CCA_Certificate.cer -alias CCARoot

如果 Web 服务需要 SSL 客户端身份验证,则一些附加步骤是必不可少的。 如果我们从未提到过客户端身份验证,那么这是不必要的。

这就是在我们的例子中修复错误的方法,但是如果我们处于不同的情况,我们可以尝试其他解决方案。

  1. 我们需要使用相同的实际密钥对再次生成证书以消除此错误。
  2. 在某些情况下,错误是由于在创建 JKS 存储和导入证书时使用相同的别名而导致的。 然后,我们需要更改别名来解决错误。
  3. 确保链中不缺少根 CA 的证书。

这篇关于解决 Java 中 the Public Keys in Reply and Keystore Don‘t Match 错误的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/688085

相关文章

在Ubuntu上部署SpringBoot应用的操作步骤

《在Ubuntu上部署SpringBoot应用的操作步骤》随着云计算和容器化技术的普及,Linux服务器已成为部署Web应用程序的主流平台之一,Java作为一种跨平台的编程语言,具有广泛的应用场景,本... 目录一、部署准备二、安装 Java 环境1. 安装 JDK2. 验证 Java 安装三、安装 mys

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

oracle数据库索引失效的问题及解决

《oracle数据库索引失效的问题及解决》本文总结了在Oracle数据库中索引失效的一些常见场景,包括使用isnull、isnotnull、!=、、、函数处理、like前置%查询以及范围索引和等值索引... 目录oracle数据库索引失效问题场景环境索引失效情况及验证结论一结论二结论三结论四结论五总结ora

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

element-ui下拉输入框+resetFields无法回显的问题解决

《element-ui下拉输入框+resetFields无法回显的问题解决》本文主要介绍了在使用ElementUI的下拉输入框时,点击重置按钮后输入框无法回显数据的问题,具有一定的参考价值,感兴趣的... 目录描述原因问题重现解决方案方法一方法二总结描述第一次进入页面,不做任何操作,点击重置按钮,再进行下

SpringCloud集成AlloyDB的示例代码

《SpringCloud集成AlloyDB的示例代码》AlloyDB是GoogleCloud提供的一种高度可扩展、强性能的关系型数据库服务,它兼容PostgreSQL,并提供了更快的查询性能... 目录1.AlloyDBjavascript是什么?AlloyDB 的工作原理2.搭建测试环境3.代码工程1.

Java调用Python代码的几种方法小结

《Java调用Python代码的几种方法小结》Python语言有丰富的系统管理、数据处理、统计类软件包,因此从java应用中调用Python代码的需求很常见、实用,本文介绍几种方法从java调用Pyt... 目录引言Java core使用ProcessBuilder使用Java脚本引擎总结引言python

SpringBoot操作spark处理hdfs文件的操作方法

《SpringBoot操作spark处理hdfs文件的操作方法》本文介绍了如何使用SpringBoot操作Spark处理HDFS文件,包括导入依赖、配置Spark信息、编写Controller和Ser... 目录SpringBoot操作spark处理hdfs文件1、导入依赖2、配置spark信息3、cont

springboot整合 xxl-job及使用步骤

《springboot整合xxl-job及使用步骤》XXL-JOB是一个分布式任务调度平台,用于解决分布式系统中的任务调度和管理问题,文章详细介绍了XXL-JOB的架构,包括调度中心、执行器和Web... 目录一、xxl-job是什么二、使用步骤1. 下载并运行管理端代码2. 访问管理页面,确认是否启动成功

Java中的密码加密方式

《Java中的密码加密方式》文章介绍了Java中使用MD5算法对密码进行加密的方法,以及如何通过加盐和多重加密来提高密码的安全性,MD5是一种不可逆的哈希算法,适合用于存储密码,因为其输出的摘要长度固... 目录Java的密码加密方式密码加密一般的应用方式是总结Java的密码加密方式密码加密【这里采用的