【问题标题】:SSL no suitable certificate foundSSL 找不到合适的证书
【发布时间】:2020-09-22 13:36:05
【问题描述】:

我知道这是一个常见错误,并且这个问题有很多重复项。虽然他们是我还没有真正找到真正的原因并解决我的问题,所以让我们开始吧。

我正在使用 Kafka,在我的信任库的服务器端,我有 4 个链。每个链代表一个证书颁发机构。每个链也作为捆绑包(Interm + Root cert)导入。 当然,每个代理都有自己的密钥库,并由 CA-1 签名。

我的客户拥有由 CA-3 签署的证书。在我客户的信任库中,我可以列出我的经纪人上的相同链。

例子:

  1. 客户端尝试进行身份验证并拥有由 CA-1 签名的证书(works
  2. 客户端尝试进行身份验证并拥有由 CA-2 签名的证书(works
  3. 客户端尝试进行身份验证并拥有由 CA-3 签名的证书(不起作用

在客户端的调试模式下我可以找到这个:

check handshake state: unknown[13]
*** CertificateRequest
Cert Types: RSA, DSS, ECDSA
Supported Signature Algorithms: SHA512withECDSA, SHA512withRSA, SHA384withECDSA, SHA384withRSA, SHA256withECDSA, SHA256withRSA, SHA256withDSA, SHA224withECDSA, SHA224withRSA, SHA224withDSA, SHA1withECDSA, SHA1withRSA, SHA1withDSA
Cert Authorities:
<CN=CA-1>
<CN=CA-2>
<CN=CA-3>
.
.
.
*** ServerHelloDone
[read] MD5 and SHA1 hashes:  len = 4
0000: 0E 00 00 00                                        ....
Warning: no suitable certificate found - continuing without client authentication
*** Certificate chain
<Empty>
*** 
.
.
.
kafka-producer-network-thread | console-producer, READ: TLSv1.2 Handshake, length = 3018
check handshake state: server_hello[2]
kafka-producer-network-thread | console-producer, fatal error: 10: Handshake message sequence violation, 2
javax.net.ssl.SSLProtocolException: Handshake message sequence violation, 2
%% Invalidated:  [Session-4, TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384]
kafka-producer-network-thread | console-producer, SEND TLSv1.2 ALERT:  fatal, description = unexpected_message
Padded plaintext before ENCRYPTION:  len = 80

现在,我不明白。应用程序能够找到代理的受信任证书(我不想在开头记录日志),能够在 CertificateRequest 中找出所有可用的 CA,但仍然无法握手。

为了确定——我获得 Interm + Root 失败客户端证书的方式是我下载了 Intermediate 证书并从 Interm 中提取了 Root 证书。制作了一个捆绑包,其中 interm 是第一个,root 是第二个,我将那个捆绑包放在信任库和密钥库中的一个别名下。

我知道这很可能是服务器信任错误,但我不知道如何更正,因为证书确实存在,并且我以与其他正在工作的人相同的方式导入了这些证书包。

如果我做错了什么,请纠正我,如果我做错了什么,请纠正我。我是 SSL 点头,想学习一些东西.. 谢谢!

【问题讨论】:

    标签: java ssl apache-kafka ssl-certificate


    【解决方案1】:

    在我的情况下,我认为在堆栈上的很多情况下是:

    • 我的客户端密钥库中没有 privKeyEntry

    如果我愿意的话:

    $ keytool -list -keystore client.keystore.jks  
    

    我会发现这个:

    primaryca, Jul 26, 2014, trustedCertEntry,
    Certificate fingerprint (SHA1): <snip>
    client, Jul 26, 2014, trustedCertEntry,
    Certificate fingerprint (SHA1):  <snip>
    

    如您所见,客户端证书的密钥库中没有 PrivateKeyEntry

    所以我从头开始。

    # Creating client keystore
    $ openssl pkcs12 -export -in client_certificate.crt -inkey client_certificate.key -certfile client_certificate.crt -out client.p12
    $ keytool -importkeystore -srckeystore client.p12 -srcstoretype pkcs12 -destkeystore client.keystore.jks -deststoretype JKS
    
    # add bundle (interm + root)
    $ keytool -keystore client.keystore.jks -alias CArootbundle -import -file bundle.pem
    

    现在,在列出密钥库之后:

    CArootbundle, Jul 26, 2014, trustedCertEntry,
    Certificate fingerprint (SHA1): <snip>
    1, Jul 26, 2014, PrivateKeyEntry,
    Certificate fingerprint (SHA1):  <snip>
    

    在我使用新创建的密钥库启动我的应用程序后,一切都开始工作了 :)

    希望我能帮助到别人!

    干杯

    【讨论】:

    • 这里的错误是您在导入生成密钥对和 CSR 时使用的签名证书时没有使用相同的别名。许多重复。
    猜你喜欢
    • 2018-10-25
    • 2022-01-02
    • 2018-08-12
    • 1970-01-01
    • 1970-01-01
    • 2011-04-14
    • 2021-04-10
    • 1970-01-01
    • 2013-09-15
    相关资源
    最近更新 更多