【发布时间】:2021-04-11 07:51:22
【问题描述】:
我尝试使用 OkHttp 客户端调用 API,但在 Android 中没有成功。该 API 在 iOS 和 Postman 上运行良好。
我仅在 Android 中收到 SSLHandshakeException。那么,究竟是什么原因,又该如何解决呢?
OkHttp 库
implementation 'com.squareup.okhttp3:okhttp:3.9.0'
implementation 'com.squareup.okhttp3:logging-interceptor:3.9.0'
Http 客户端
HttpLoggingInterceptor logging = new HttpLoggingInterceptor();
logging.setLevel(HttpLoggingInterceptor.Level.BODY);
OkHttpClient.Builder builder = new OkHttpClient().newBuilder();
if (BuildConfig.DEBUG)
builder.addInterceptor(logging);
OkHttpClient client= builder.build();
日志:
javax.net.ssl.SSLHandshakeException: Chain validation failed
at com.android.org.conscrypt.SSLUtils.toSSLHandshakeException(SSLUtils.java:362)
at com.android.org.conscrypt.ConscryptEngine.convertException(ConscryptEngine.java:1134)
at com.android.org.conscrypt.ConscryptEngine.readPlaintextData(ConscryptEngine.java:1089)
at com.android.org.conscrypt.ConscryptEngine.unwrap(ConscryptEngine.java:876)
at com.android.org.conscrypt.ConscryptEngine.unwrap(ConscryptEngine.java:747)
at com.android.org.conscrypt.ConscryptEngine.unwrap(ConscryptEngine.java:712)
at com.android.org.conscrypt.ConscryptEngineSocket$SSLInputStream.processDataFromSocket(ConscryptEngineSocket.java:849)
at com.android.org.conscrypt.ConscryptEngineSocket$SSLInputStream.access$100(ConscryptEngineSocket.java:722)
at com.android.org.conscrypt.ConscryptEngineSocket.doHandshake(ConscryptEngineSocket.java:238)
at com.android.org.conscrypt.ConscryptEngineSocket.startHandshake(ConscryptEngineSocket.java:217)
at okhttp3.internal.connection.RealConnection.connectTls(RealConnection.java:299)
at okhttp3.internal.connection.RealConnection.establishProtocol(RealConnection.java:268)
at okhttp3.internal.connection.RealConnection.connect(RealConnection.java:160)
at okhttp3.internal.connection.StreamAllocation.findConnection(StreamAllocation.java:256)
at okhttp3.internal.connection.StreamAllocation.findHealthyConnection(StreamAllocation.java:134)
at okhttp3.internal.connection.StreamAllocation.newStream(StreamAllocation.java:113)
at okhttp3.internal.connection.ConnectInterceptor.intercept(ConnectInterceptor.java:42)
经过测试的设备和操作系统版本
- 一加 6T (Android 10)
- 三星 s5 (Android 9)
- 三星 A5(安卓 6)
- Android 模拟器 (Android 11)
- LG Nexus(安卓 6)
【问题讨论】:
-
此错误类型意味着设备 SSL 堆栈无法验证服务证书。您使用的是哪个 Android 版本,您尝试连接的服务是什么?
-
@DominikMurzynowski 三星 s6 (android 9) 和 Onplus 6T (android 10)
-
没有@YuriSchimke 已经提到它
-
@RajasekaranM 检查您的移动设备日期并检查模拟器
-
检查链接原因异常,toSSLHandshakeException 应该保留它。
标签: java android okhttp webservice-client