使用Retrofit+OkHttp作为网络请求框架,发现一个问题,就是每隔一定时间再请求接口,会返回一个Unexpected end of stream on Connection...http1.1的错误,经历了一段了解,发现问题所在:
客户端与服务端使用TCP协议连接,客户端之后会复用之前的连接,但是服务端此时已经处于TCP的FIN_WAIT2状态了,因此此时客户端再去连接就不成功了。
亲身试验,可解决的办法:
首先,创建一个网络拦截器:
public class NetInterceptorimplements Interceptor {
@Override
public Responseintercept(Chain chain)throws IOException {
//请求完成后断开,下次请求时先连接
Request request = chain.request()
.newBuilder()
.addHeader("Connection", "close")
.build();
return chain.proceed(request);
}
}
然后,设置这个网络拦截器:
OkHttpClient client =new OkHttpClient.Builder()
.addNetworkInterceptor(new NetInterceptor()) //添加网络拦截器
.connectTimeout(30, TimeUnit.SECONDS)
.readTimeout(30, TimeUnit.SECONDS)
.retryOnConnectionFailure(false)
.build();
网上有做法是retryOnConnectionFailure(false)这里填true,但是我试验发现我这样做,填了false也没有再出现这个问题。