Android之Unexpected end of stream on Connection问题解决

使用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也没有再出现这个问题。

你可能感兴趣的:(Android之Unexpected end of stream on Connection问题解决)