请教一个 Apache HttpClient 中 SSLConnectionSocketFactory 的 supportedProtocols 的问题

2019-10-31 23:59:37 +08:00
 xudzhang

我使用下面的 factory 初始化了一个 HttpClient:

sslsf = new SSLConnectionSocketFactory(builder.build(), new String[]{"SSLv2Hello", "SSLv3", "TLSv1", "TLSv1.1", "TLSv1.2"}, null, NoopHostnameVerifier.INSTANCE);

当我使用这个 client 给第三方 service 发送 HTTP 请求时,永远抛 socket 的 connection reset 异常。 我做了个尝试,把上面的语句改成下面的(删掉 SSLv2Hello 和 SSLv3 ):

sslsf = new SSLConnectionSocketFactory(builder.build(), new String[]{"TLSv1", "TLSv1.1", "TLSv1.2"}, null, NoopHostnameVerifier.INSTANCE);

然后再次发送请求,就一切正常了。此处不解的是,SSLConnectionSocketFactory 那个构造函数的第二个参数是 supportedProtocols,为什么我定义多了反而不行?这个参数是怎么个机理?谢谢。

5897 次点击
所在节点    Java
2 条回复
xy90321
2019-11-01 00:05:39 +08:00
原因可能有很多
最可能的是对面不支持 tls 以下的旧版协议
所以就会 reset 你
先看一下具体的 message 再说咯
xudzhang
2019-11-01 00:08:30 +08:00
@xy90321 请教一下,你说的 message 具体是在哪看的?

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/615059

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX