java - 不偶尔发送证书

标签 java ssl handshake sslhandshakeexception

在我的应用程序中,我有 2 个组件通过 REST(基于客户端-服务器)相互通信。
该应用程序可以配置为使用 HTTP 或 HTTPS(自签名证书)。

有时,当我在 HTTPS 模式下启动我的应用程序时,我的客户端无法与服务器通信。我收到以下异常:

    09-16-2013 12:28:52 [dispatcher] [http-nio-8143-exec-8] [INFO] - Exception while dispatching request
java.util.concurrent.ExecutionException: com.sun.jersey.api.client.ClientHandlerException: javax.net.ssl.SSLHandshakeException: Remote host closed connection during handshake
    ...
Caused by: com.sun.jersey.api.client.ClientHandlerException: javax.net.ssl.SSLHandshakeException: Remote host closed connection during handshake
    ...
Caused by: javax.net.ssl.SSLHandshakeException: Remote host closed connection during handshake
    ...
Caused by: java.io.EOFException: SSL peer shut down incorrectly
    ...

当我停止并启动应用程序时,一切都按预期工作。
我尝试搜索解决方案,但时不时发生并通过重启修复的问题找不到与我的问题相似的任何问题,所有问题都是一致的。

Java 版本:Oracle Corporation,“Java HotSpot(TM) 64 位服务器虚拟机”,1.7.0_17-b02 操作系统:红帽 有什么想法吗?

更新
事实证明,这也可能在应用程序运行一段时间后发生。意思是,一切正常,SSL 通信正常,突然出现此错误,并且在我重新启动客户端之前不会解决。

我能够通过 -Djavax.net.debug=all 重现该问题,显然客户端未发送证书,问题是为什么。有时一切都很顺利,但有时会出现问题的原因是什么?

客户端:

pool-4-thread-2, WRITE: TLSv1 Handshake, length = 48
pool-4-thread-2, waiting for close_notify or alert: state 1
pool-4-thread-2, received EOFException: error
pool-4-thread-2, Exception while waiting for close javax.net.ssl.SSLHandshakeException: Remote host closed connection during handshake
pool-4-thread-2, handling exception: javax.net.ssl.SSLHandshakeException: Remote host closed connection during handshake
%% Invalidated:  [Session-7, TLS_RSA_WITH_AES_128_CBC_SHA]
pool-4-thread-2, SEND TLSv1 ALERT:  fatal, description = handshake_failure
Padded plaintext before ENCRYPTION:  len = 32
0000: 02 28 7A 8E 21 1F 09 1A   5F 00 5C 42 6B 12 33 D8  .(z.!..._.\Bk.3.
0010: 73 F0 58 DD 0D D9 09 09   09 09 09 09 09 09 09 09  s.X.............
pool-4-thread-2, WRITE: TLSv1 Alert, length = 32
pool-4-thread-2, Exception sending alert: java.net.SocketException: Broken pipe
pool-4-thread-2, called closeSocket()
Keep-Alive-Timer, called close()
Keep-Alive-Timer, called closeInternal(true)
Keep-Alive-Timer, SEND TLSv1 ALERT:  warning, description = close_notify
Padded plaintext before ENCRYPTION:  len = 32
0000: 01 00 FD 8B FE 50 2A 16   8A FC 10 F7 E0 05 7E D1  .....P*.........
0010: 0A 78 A0 03 84 26 09 09   09 09 09 09 09 09 09 09  .x...&..........
Keep-Alive-Timer, WRITE: TLSv1 Alert, length = 32
[Raw write]: length = 37
0000: 15 03 01 00 20 24 CC 05   7B DA AA 98 D7 BC 49 07  .... $........I.
0010: 59 94 A4 42 A1 D9 22 42   34 C2 75 1B 9E 36 F0 23  Y..B.."B4.u..6.#
0020: 58 9D 80 8D 38                                     X...8
Keep-Alive-Timer, called closeSocket(selfInitiated)

服务器端:

http-nio-8243-exec-2, READ: TLSv1 Handshake, length = 269
*** Certificate chain
***
http-nio-8243-exec-2, fatal error: 42: null cert chain
javax.net.ssl.SSLHandshakeException: null cert chain
%% Invalidated:  [Session-5, TLS_RSA_WITH_AES_128_CBC_SHA]
http-nio-8243-exec-2, SEND TLSv1 ALERT:  fatal, description = bad_certificate
http-nio-8243-exec-2, WRITE: TLSv1 Alert, length = 2
http-nio-8243-exec-2, fatal: engine already closed.  Rethrowing javax.net.ssl.SSLHandshakeException: null cert chain
http-nio-8243-exec-2, called closeOutbound()
http-nio-8243-exec-2, closeOutboundInternal()
http-nio-8243-ClientPoller-1, called closeOutbound()
http-nio-8243-ClientPoller-1, closeOutboundInternal()
http-nio-8243-ClientPoller-1, SEND TLSv1 ALERT:  warning, description = close_notify

最佳答案

javax.net.ssl.SSLHandshakeException: null cert chain

看起来服务器需要客户端证书,而您没有发送证书,或者发送的内容无效。您将在客户端 SSL 日志的更上方有一个入站 CertificateRequest,它后面没有出站 Certificate 消息,或者后面跟着一个空消息。

关于java - 不偶尔发送证书,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18826456/

相关文章:

java - 字体扩展不适用于 JasperReports

java - 在Java中获取视频文件元数据

java - Spring mvc @RequestBody如何用@EmbeddedId解析JPA实体

node.js - 如何使用nodejs中的ws npm模块从客户端向WebSocket服务器发送 "Upgrade"握手?

java - 确定 Java 中 TLS 握手的 Diffie-Hellman "Parameters"长度

r - 运行 weathercan 包时出错 - 致命 SSL/TLS 警报(例如握手失败))

java - 多维数组可以在java中如何处理它们中的两种不同类型

ruby - 无法通过 ssl 通过 smtp 发送电子邮件

php - .htaccess 中的强制 https 重定向导致/admin 被重定向到/

php - 使用 php 5.6 的邮件(xampp 1.8.3 - 窗口 8)