useSystemProperties() 不适用于 Apache HttpClientBuilder.create() 版本 4.5.6
useSystemProperties() is not working with Apache HttpClientBuilder.create() version 4.5.6
我在 Vanilla Spring 4.2.5.RELEASE 和 JDK 1.7 上有一个项目 运行,它使用 RestTemplate 和 PoolingHttpClientConnectionManager,我已经将客户端初始化为使用系统属性
private HttpClient httpClient() {
PoolingHttpClientConnectionManager poolingHttpClientConnectionManager = new PoolingHttpClientConnectionManager();
poolingHttpClientConnectionManager.setMaxTotal(300);
poolingHttpClientConnectionManager.setDefaultMaxPerRoute(200);
return HttpClientBuilder
.create()
.useSystemProperties()
.setConnectionManager(poolingHttpClientConnectionManager)
.build();
}
并设置以下系统属性 -Dhttps.protocols=TLSv1.2
我对这种行为一无所知,我试过像这样创建自定义 SSLConnectionSocketFactory
并且成功了
SSLConnectionSocketFactory sslConnectionSocketFactory =
new SSLConnectionSocketFactory(SSLContexts.createDefault(),
new String[]{"TLSv1.2"},
null,
SSLConnectionSocketFactory.getDefaultHostnameVerifier());
PoolingHttpClientConnectionManager poolingHttpClientConnectionManager =
new PoolingHttpClientConnectionManager(
RegistryBuilder.<ConnectionSocketFactory>create()
.register("http", PlainConnectionSocketFactory.getSocketFactory())
.register("https", sslConnectionSocketFactory)
.build());
但我还有一个问题需要解决,即用于 https 调用的 trustStore,此应用程序部署在 IBM WebSphere 中,并且由于 httpClient 未使用 WebSphere 服务器设置的 systemProperties,我应该添加另一个代码片段(以指向 IBM TrustStore),我不想这样做,因为它的工作量太大,理想情况下 useSystemProperties() 应该可以解决这两个问题...
SSLContext sslContext = SSLContexts
.custom()
.loadKeyMaterial(ResourceUtils.getFile(keystoreLocation), null, keystorePassword.toCharArray())
.loadTrustMaterial(ResourceUtils.getFile((truststoreLocation)), truststorePassword.toCharArray())
.build();
请帮助如何进行...谢谢
经过一些调试后我发现调用useSystemProperties()
不会对我们设置connectionManager有任何影响,在.build()
函数中,有一个if条件来检查connectionManager是否设置( 参考下面的图片),只有当它没有设置时,它才会使用 systemProperties(因为指定连接管理器是关于如何进行远程调用的低级别定制,我们应该在 PoolingHttpClientConnectionManager 初始化本身中设置)
PoolingHttpClientConnectionManager poolingHttpClientConnectionManager = new
PoolingHttpClientConnectionManager(RegistryBuilder
.create()
.register("http", PlainConnectionSocketFactory.getSocketFactory())
.register("https", SSLConnectionSocketFactory.getSystemSocketFactory())
.build());
SSLConnectionSocketFactory.getSystemSocketFactory()
最重要
我在 Vanilla Spring 4.2.5.RELEASE 和 JDK 1.7 上有一个项目 运行,它使用 RestTemplate 和 PoolingHttpClientConnectionManager,我已经将客户端初始化为使用系统属性
private HttpClient httpClient() {
PoolingHttpClientConnectionManager poolingHttpClientConnectionManager = new PoolingHttpClientConnectionManager();
poolingHttpClientConnectionManager.setMaxTotal(300);
poolingHttpClientConnectionManager.setDefaultMaxPerRoute(200);
return HttpClientBuilder
.create()
.useSystemProperties()
.setConnectionManager(poolingHttpClientConnectionManager)
.build();
}
并设置以下系统属性 -Dhttps.protocols=TLSv1.2
我对这种行为一无所知,我试过像这样创建自定义 SSLConnectionSocketFactory
并且成功了
SSLConnectionSocketFactory sslConnectionSocketFactory =
new SSLConnectionSocketFactory(SSLContexts.createDefault(),
new String[]{"TLSv1.2"},
null,
SSLConnectionSocketFactory.getDefaultHostnameVerifier());
PoolingHttpClientConnectionManager poolingHttpClientConnectionManager =
new PoolingHttpClientConnectionManager(
RegistryBuilder.<ConnectionSocketFactory>create()
.register("http", PlainConnectionSocketFactory.getSocketFactory())
.register("https", sslConnectionSocketFactory)
.build());
但我还有一个问题需要解决,即用于 https 调用的 trustStore,此应用程序部署在 IBM WebSphere 中,并且由于 httpClient 未使用 WebSphere 服务器设置的 systemProperties,我应该添加另一个代码片段(以指向 IBM TrustStore),我不想这样做,因为它的工作量太大,理想情况下 useSystemProperties() 应该可以解决这两个问题...
SSLContext sslContext = SSLContexts
.custom()
.loadKeyMaterial(ResourceUtils.getFile(keystoreLocation), null, keystorePassword.toCharArray())
.loadTrustMaterial(ResourceUtils.getFile((truststoreLocation)), truststorePassword.toCharArray())
.build();
请帮助如何进行...谢谢
经过一些调试后我发现调用useSystemProperties()
不会对我们设置connectionManager有任何影响,在.build()
函数中,有一个if条件来检查connectionManager是否设置( 参考下面的图片),只有当它没有设置时,它才会使用 systemProperties(因为指定连接管理器是关于如何进行远程调用的低级别定制,我们应该在 PoolingHttpClientConnectionManager 初始化本身中设置)
PoolingHttpClientConnectionManager poolingHttpClientConnectionManager = new
PoolingHttpClientConnectionManager(RegistryBuilder
.create()
.register("http", PlainConnectionSocketFactory.getSocketFactory())
.register("https", SSLConnectionSocketFactory.getSystemSocketFactory())
.build());
SSLConnectionSocketFactory.getSystemSocketFactory()
最重要