0
点赞
收藏
分享

微信扫一扫

okhttp经常出现SocketTimeoutException


最近开发时android时,发现一个bug,退后台的app,再回前台时,在onResume中调用api经常出现java.net.SocketTimeoutException。

当时的网络环境是可以的:有网络,服务器也正常。于是在网上找了一下,终于在这篇文章里找到了答案:​​https://github.com/square/okhttp/issues/3146​​​和​​https://stackoverflow.com/questions/39219094/sockettimeoutexception-in-retrofit​​

一开始,我创建的okhttpclient的方式:

val clientBuilder = new OkHttpClient.Builder()
.readTimeout(readTimeoutMillis, TimeUnit.MILLISECONDS)
.writeTimeout(writeTimeoutMillis, TimeUnit.MILLISECONDS)
.connectTimeout(connectTimeoutMillis, TimeUnit.MILLISECONDS)
.retryOnConnectionFailure(true)

改善的方法就是加多下面两行:

.connectionPool(ConnectionPool(0, 1, TimeUnit.NANOSECONDS));
.protocols(listOf(Protocol.HTTP_1_1))

最后的代码如下

val clientBuilder = new OkHttpClient.Builder()
.readTimeout(readTimeoutMillis, TimeUnit.MILLISECONDS)
.writeTimeout(writeTimeoutMillis, TimeUnit.MILLISECONDS)
.connectTimeout(connectTimeoutMillis, TimeUnit.MILLISECONDS)
.retryOnConnectionFailure(true)
.connectionPool(ConnectionPool(0, 1, TimeUnit.NANOSECONDS));
.protocols(listOf(Protocol.HTTP_1_1))

这样的代码运行起来就没有经常出现这个异常了。


举报

相关推荐

程序编制中经常出现的问题

0 条评论