OkHttp responsejava.lang.IllegalStateException: closed

java.lang.IllegalStateException: closed
    at okio.RealBufferedSource.rangeEquals(RealBufferedSource.java:408)

非法 语句异常。造成这个异常的原因就是在使用response.body().string() 的时候进行了多次调用。

如下所示:

 postanays(url, post, new okhttp3.Callback() {
            private String str;
            @Override
            public void onResponse(Call call, final Response response) {
                try {
                    System.out.println(Thread.currentThread().getName() + "" + response.body().string());
                } catch (IOException e) {
                    e.printStackTrace();
                }
               
                handler.post(new Runnable() {
                    @Override
                    public void run() {
                        if (listener != null) {
                            System.out.println(Thread.currentThread().getName());
                            try {
                                listener.success(response.body().string());
                            } catch (IOException e) {
                                e.printStackTrace();
                            }
                        }
                    }
                });
            }
            @Override
            public void onFailure(Call call, final IOException e) {
                handler.post(new Runnable() {
                    @Override
                    public void run() {
                        listener.error(e + "");
                    }
                });
            }
        });
因为在获取值得时候 在前面已经掉用过了response.body().string()方法进行打印,然后在后面又调用了一次。所以造成了这个异常。
   */
  public final String string() throws IOException {
    BufferedSource source = source();
    try {
      Charset charset = Util.bomAwareCharset(source, charset());
      return source.readString(charset);
    } finally {
      Util.closeQuietly(source);
    }
  }

上面这段代码就是.string()的源码,可以看到他的return之后还在finally里面关闭了资源。所以了response.body().string()方法不能被调用第二次。


当我 改完后,重新运行,发现还是报错。但是报的错不一样了。代码和错误如下所示:
 postanays(url, post, new okhttp3.Callback() {
            private String str;
            @Override
            public void onResponse(Call call, final Response response) {
                handler.post(new Runnable() {
                    @Override
                    public void run() {
                        if (listener != null) {
                            try {
                                listener.success(response.body().string());
                            } catch (IOException e) {
                                e.printStackTrace();
                            }
                        }
                    }
                });
            }
            @Override
            .....

错误为 android.os.NetworkOnMainThreadException 主线程访问网络异常。

经过一系列的研究,response.body()的时候在body这个方法里面 会有网络耗时的操作。所以才会造成这个错误。

修改如下:

public void postanay(String url, String post, final OnReqeustListener listener) {
        postanays(url, post, new okhttp3.Callback() {
            private String str;
            @Override
            public void onResponse(Call call, final Response response) {
                try {
                    str = response.body().string();
                } catch (IOException e) {
                    e.printStackTrace();
                }
                handler.post(new Runnable() {
                    @Override
                    public void run() {
                        if (listener != null) {
                            listener.success(str);
                        }
                    }
                });
            }

在handler 将数据发送到 主线程之前 将response.body().string()的结果赋给一个变量。然后用handler直接发送到的主线程就可以了。

以上就是 我遇到的bug。是不是特别坑。 如果以上文章存在错误,还请指出,谢谢!

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Tʀᴜsᴛ³⁴⁵

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值