【问题标题】:OkHttpClient.Builder sslSocketFactory is deprecatedOkHttpClient.Builder sslSocketFactory 已弃用
【发布时间】:2017-03-22 21:20:16
【问题描述】:

我正在尝试使用 (retrofit 2.0, okhttp3) 进行 https 调用 但它显示 sslSocketFactory(getSSLConfig()) 已弃用并提供其他选项
sslSocketFactory(SSLSocketFactory sslSocketFactory, X509TrustManager trustManager)
我想更新我的代码并使用新选项而不是不推荐使用的方法 我在网上搜索但找不到任何好的参考。如果有人能对这个问题提供一些很好的参考将非常有帮助

【问题讨论】:

标签: android retrofit2 okhttp3


【解决方案1】:

您需要有效的证书。创建信任任何 ssl 证书的受信任 OkHttpClient。试试这个代码:

TrustManagerFactory trustManagerFactory = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm());
trustManagerFactory.init((KeyStore) null);
TrustManager[] trustManagers = trustManagerFactory.getTrustManagers();
if (trustManagers.length != 1 || !(trustManagers[0] instanceof X509TrustManager)) {
throw new IllegalStateException("Unexpected default trust managers:" + Arrays.toString(trustManagers));
}
X509TrustManager trustManager = (X509TrustManager) trustManagers[0];
SSLContext sslContext = SSLContext.getInstance("SSL");
sslContext.init(null, new TrustManager[] { trustManager }, null);
SSLSocketFactory sslSocketFactory = sslContext.getSocketFactory();
OkHttpClient client = new OkHttpClient.Builder().sslSocketFactory(sslSocketFactory, trustManager);

更多信息在这里:Now that SSLSocketFactory is deprecated on Android, what would be the best way to handle Client Certificate Authentication?

【讨论】:

  • 我得到 SSLHandshakeException: connection closed by peer
猜你喜欢
  • 2014-02-12
  • 1970-01-01
  • 2016-03-03
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2020-04-20
  • 1970-01-01
相关资源
最近更新 更多