原文链接:点击打开链接
===============================================================================================
1、问题 :Okhttp 网络请求使用Interceptor拦截器后报错,原因是response.body().string()只能调用一次,调用一次后io流会close,再次调用response.body().string()就会报错java.lang.IllegalStateException: closed。
在自定义的Interceptor调用了response.body().string()一次,在CallBack又调用了一次,故报错失败。。。
2、解决方式:
查看鸿神在OkhttpUtils框架中的LoggerInterceptor源码发现,在获取到响应结果Response后
使用
response.newBuilder().build()得到Response的克隆对象,里面的内容和原Response对象完全一致,用克隆对象来输出log,完美解决。