意外的流结束改造 [英] unexpected end of stream retrofit

查看:63
本文介绍了意外的流结束改造的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个安卓应用程序,它向Flask中的睡觉API发出Http请求。我正在使用带有okhttp3的Retrofit2向托管在带有Raspbian Lite的Raspberry PI上的服务器发出请求。 我的问题是,有时我会收到IOException->java.net.ProtocolException:意外的流结束 但它有时会发生,有时会完美地发挥作用。 Http客户端搭建如下:

OkHttpClient.Builder httpClient = new OkHttpClient.Builder();
httpClient.addInterceptor(new Interceptor() {
        @NotNull
        @Override
        public Response intercept(@NotNull Chain chain) throws IOException {
            Request original = chain.request();

            Request request = original.newBuilder()
                    .header("User-Agent","myUserAgent")
                    .header("Connection","close")
                    .addHeader("Accept-Encoding", "identity")
                    .method(original.method(),original.body())
                    .build();

            return chain.proceed(request);
        }
    });
Retrofit retrofit=null;
    try {
         retrofit = new Retrofit.Builder()
                .baseUrl(baseUrl)
                .addConverterFactory(GsonConverterFactory.create())
                .client(httpClient.build())
                .build();

    }catch (Exception e){
         //Log.d

    }
ApiService API_SERVICE=null;
    try{
        API_SERVICE = retrofit.create(ApiService.class);
    }catch (Exception e){
        //Log.d
    }

    return API_SERVICE;

我尝试过使用和不使用日志拦截器,使用Accept-Encoding:Identity and Conecction:Close。但这不管用。 答案的内容长度是4339(由邮递员表示),在问询中也表示为4339 这是我得到的异常:

我正在使用Android Studio和Android API28中的仿真器。我的电脑和树莓都是通过以太网线连接到互联网的。 我不明白的是,为什么有时请求会起作用,而有时会直接转到onFailure。 在服务器上,我总是得到一个200代码。请求得到处理并正确返回响应。 我还可以尝试什么?

推荐答案

似乎是Android Studio仿真器有问题。我已尝试将我的智能手机连接到Android Studio,并在另一部智能手机上安装APK,但问题没有重现。

这篇关于意外的流结束改造的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆