2016-07-29 11 views
1

うまく動作するコードがありますが、現在は推奨されていません。 BasicCredentialsProvider推奨されていないHttpClientは、現在apache-httpclient-4.3.xを使用しています

SSLSocketFactory sslsf = new SSLSocketFactory("TLS", null, null, keyStore, null, new TrustSelfSignedStrategy(), 
       new AllowAllHostnameVerifier()); 
     Scheme https = new Scheme("https", 28181, sslsf); 

     SchemeRegistry schemeRegistry = new SchemeRegistry(); 
     schemeRegistry.register(new Scheme("http", 80, PlainSocketFactory.getSocketFactory())); 
     schemeRegistry.register(https); 

     PoolingClientConnectionManager connectionManager = new PoolingClientConnectionManager(schemeRegistry); 
     connectionManager.setMaxTotal(100); 
     connectionManager.setDefaultMaxPerRoute(5); 

     DefaultHttpClient httpClient = new DefaultHttpClient(connectionManager); 

     BasicCredentialsProvider credsProvider = new BasicCredentialsProvider(); 
     credsProvider.setCredentials(new AuthScope(uri.getHost(), uri.getPort(), name), 
       new UsernamePasswordCredentials(username, password)); 

     httpClient.setCredentialsProvider(credsProvider); 
     httpClient.getParams().setIntParameter(CoreConnectionPNames.SO_TIMEOUT, 60000); 

     return new HttpContextRequestScopedApacheClientExecutor(httpClient); 

私はそれを自分でやってみました。まず、私は

SSLConnectionSocketFactory sslConnectionFactory = new SSLConnectionSocketFactory 
(SSLContexts.custom(). 
        loadTrustMaterial(keyStore, new TrustSelfSignedStrategy()). 
useTLS().build(), SSLConnectionSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER); 

SSLSocketFactoryを交換し、その後、私は

Registry<ConnectionSocketFactory> registry = RegistryBuilder.<ConnectionSocketFactory>create() .register("https", sslConnectionFactory) .build();

を使用しようとした私はそこに私のポートに合うことができなかったので、私はかなりの時間を探した後、私はまだどのようにに失われていますそれをやる。残りの部分についてはまだ解決策がありません。これについての助けがあれば誰も助けてくれるでしょう。

答えて

0

私はそれをすることができたと思う、それは今まで働いている。

HttpClientBuilder builder = HttpClientBuilder.create(); 
    KeyStore keyStore = initSSL(); 

    SSLConnectionSocketFactory sslConnectionFactory = new SSLConnectionSocketFactory(SSLContexts.custom().loadTrustMaterial(keyStore, new 
    TrustSelfSignedStrategy()).useTLS().build(), SSLConnectionSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER); 

    Registry<ConnectionSocketFactory> registry = RegistryBuilder.<ConnectionSocketFactory>create() 
      .register("http", PlainConnectionSocketFactory.getSocketFactory()) 
      .register("https", sslConnectionFactory) 
      .build(); 

    PoolingHttpClientConnectionManager ccm = new PoolingHttpClientConnectionManager(registry); 
    ccm.setMaxTotal(100); 
    ccm.setDefaultMaxPerRoute(5); 
    builder.setConnectionManager(ccm); 

    BasicCredentialsProvider credsProvider = new BasicCredentialsProvider(); 
    credsProvider.setCredentials(new AuthScope(uri.getHost(), uri.getPort(), name), 
      new UsernamePasswordCredentials(username, password)); 

    builder.setDefaultCredentialsProvider(credsProvider); 

    RequestConfig.Builder requestBuilder = RequestConfig.custom(); 
    requestBuilder.setSocketTimeout(60000); 
    builder.setDefaultRequestConfig(requestBuilder.build()); 

    return new HttpContextRequestScopedApacheClientExecutor(builder.build()); 
関連する問題