首页 > 解决方案 > Android应用程序崩溃okhttp3 HTTP FAILED:javax.net.ssl.SSLException:读取错误:系统调用期间I/O错误,软件导致连接中止

问题描述

我正在开发 android 原生 kotlin 项目。
我正在使用Android 版本 10的 android real Oneplus 6设备中测试应用程序。 请从 build.gradle 文件中找到以下详细信息,了解我用于项目的最新 okhttp 和改造依赖项。 好的http

implementation "com.squareup.okhttp3:okhttp:4.9.0"
implementation "com.squareup.okhttp3:logging-interceptor:4.9.0"` 

改造

implementation 'com.squareup.retrofit2:retrofit:2.9.0'
implementation 'com.squareup.retrofit2:converter-gson:2.9.0'

我已经为 okhttpclient 设置了相关的超时时间。

.connectTimeout(HTTP_CONNECT_TIMEOUT, TimeUnit.SECONDS)
.readTimeout(HTTP_READ_TIMEOUT, TimeUnit.SECONDS)
.writeTimeout(HTTP_WRITE_TIMEOUT, TimeUnit.SECONDS)

我正在使用okhttp3.Interceptor。请在下面找到实现。

import okhttp3.Interceptor
import okhttp3.Request
import okhttp3.Response

class AuthorizationInterceptor(private val sharedPreferenceService: SharedPreferenceService) :
    Interceptor {

    override fun intercept(chain: Interceptor.Chain): Response {
        val requestBuilder = chain.request().newBuilder()
            .addHeader("Content-Type", "application/json")
            .addHeader("Accept", "application/json")

        return chain.proceed(requestBuilder.build())
    }
  }

观察/问题

  1. 如果 API 调用正在进行,并且我们尝试更改或禁用网络/互联网,那么只要从上面的代码片段执行下面的行,okhttp3 本身就会在内部崩溃,因此应用程序正在崩溃。 return chain.proceed(requestBuilder.build())

我从我的 android studio 中找到了下面的 okhttp 内部崩溃日志,可以帮助您找到根本原因和修复。

FATAL EXCEPTION: main
    Process: com.pg.posm, PID: 8770
    javax.net.ssl.SSLException: Read error: ssl=0x7afca87588: I/O error during system call, Software caused connection abort
E/AndroidRuntime: FATAL EXCEPTION: main
    Process: com.pg.posm, PID: 26238
    java.net.ConnectException: Failed to connect to hostname/ip:port

我还尝试使用 try-catch 将拦截器片段包装在上面,但 okhttp3 本身仍然崩溃,因此 App 崩溃了。
我们没有任何控制来解决它。
请在下面找到带有包装的 try-catch 实现的拦截器片段。

import okhttp3.Interceptor
import okhttp3.Request
import okhttp3.Response
import timber.log.Timber
import java.io.IOException

class AuthorizationInterceptor(private val sharedPreferenceService: SharedPreferenceService) :
    Interceptor {

    @Throws(IOException::class)
    override fun intercept(chain: Interceptor.Chain): Response {
        val requestBuilder = chain.request().newBuilder()
            .addHeader("Content-Type", "application/json")
            .addHeader("Accept", "application/json")
     
        try {
            return chain.proceed(requestBuilder.build())
        }catch (e: Throwable) {
            
            if (e is IOException) {
                
                throw e
            } else {
                
                throw IOException(e)
            }
        }
    }   
}

任何人都可以尝试使用相关设置和代码片段制作小型 android 项目并查看。
请为世界上许多人面临的这个阻止程序问题提供必要的修复或方法。
如果您需要更多详细信息,请告诉我。我很乐意为您提供。

标签: androidkotlinretrofit2okhttpinterceptor

解决方案


我正在努力解决这个问题。事实上,这个错误并不奇怪。

正如你所说

如果 API 调用正在进行,并且我们尝试更改或禁用网络/互联网,那么只要从上面的代码片段执行下面的行,okhttp3 本身就会在内部崩溃,因此应用程序正在崩溃。

为什么这对你来说如此奇怪?

如日志所示

FATAL EXCEPTION: main
Process: com.pg.posm, PID: 8770
javax.net.ssl.SSLException: Read error: ssl=0x7afca87588: I/O error during system call,
Software caused connection abort

你有一个 SSL/TLS 连接,这意味着,在建立与服务器的连接和传输数据之前,有很多员工是透明地发生的,例如:

  • 握手
  • 发送/接收公钥
  • 生成会话密钥
  • 建立安全通道

上述操作以及安全通道仅对当前连接的安全套接字有效,对任何其他安全套接字无效。

再次支持你的陈述

如果 API 调用正在进行中并且我们尝试更改或禁用网络/互联网

实际上,上述操作使之前连接的安全套接字无效并抛出 SslException(MitM 保护)。

我希望以上陈述对您有所帮助。


推荐阅读