android - 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())
}
}
观察/问题
- 如果 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 项目并查看。
请为世界上许多人面临的这个阻止程序问题提供必要的修复或方法。
如果您需要更多详细信息,请告诉我。我很乐意为您提供。
解决方案
我正在努力解决这个问题。事实上,这个错误并不奇怪。
正如你所说
如果 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 保护)。
我希望以上陈述对您有所帮助。
推荐阅读
- ios - 如何使用本地 json 文件对网络请求进行单元测试?
- android - 我不知道如何使用边距在布局中移动仪表
- spring-boot - CommonsRequestLoggingFilter 在 Spring Boot 应用程序中不起作用
- node.js - 使用 JWT 进行护照身份验证:如何将护照的默认未经授权响应更改为我的自定义响应?
- graphql - “queryAll”查询类型中的 nextToken
- java - 部署工件时卡住
- php - 不会显示数据库 laravel 中的所有好友
- java - 如何处理 Spring Boot 中的 SQLIntegrityConstraintViolationException?
- python - Django中的过滤器和类别之间有区别吗
- mlr - 如何从 mlr Wrapper 获取和设置超参数