okhttp统一处理返回请求 okhttp统一处理返回数据 okhttp4.2统一处理返回请求

使用//return response    因为response.body().byte()  或 response.body()string()之后,response中的流会被关闭,程序会报错,我们需要创建出一   个新的response给应用层处理。
     
  所以 return response.newBuilder()
                        .body(ResponseBody.create(mediaType, respBytes ))
                        .build();



public class WXTokenInterceptord implements Interceptor {
 
     private final String TAG = "wx";
 
     @Override
     public Response intercept(Chain chain) throws IOException {
           Request request = chain.request() ;
          Response response = chain.proceed(request);
         
       byte[] respBytes = response.body() .bytes();
        String respString = new String(respBytes);
        try {
            JSONObject object = new JSONObject(respString);
            //处理返回数据

        } catch (JSONException e) {
            e.printStackTrace();
            
        }
         //return response ;
     MediaType mediaType = response.body().contentType();
   return response.newBuilder()
                        .body(ResponseBody.create(mediaType, respBytes ))
                        .build();
     }
     
 }
public static OkHttpClient getOkHttpClient() {
        Interceptor interceptor = new WXTokenInterceptord ();
        OkHttpClient client = new OkHttpClient.Builder()
                .connectTimeout(30 * 1000, TimeUnit.MILLISECONDS)
                .readTimeout(30 * 1000, TimeUnit.MILLISECONDS)
                .addInterceptor(interceptor)
                .addInterceptor(new HttpLoggingInterceptor(new MyLog()).setLevel(HttpLoggingInterceptor.Level.BODY))
                .build();
        return client;
    }

 

 如果出现 error     

      okio.RealBufferedSource.request(RealBufferedSource.java:65)

改用下面方案  2  :

因为response.body().byte()  或 response.body()string()之后,response中的流会被关闭,程序会报错,我们需要创建出一   个新的response给应用层处理

public class WXTokenInterceptord implements Interceptor {
 
     private final String TAG = "wx";
 
     @Override
     public Response intercept(Chain chain) throws IOException {
           Request request = chain.request() ;
          Response response = chain.proceed(request);
         
     
        try {
            JSONObject object = new JSONObject(respString);
            //处理返回数据
//因为response.body().string()之后,response中的流会被关闭,程序会报错,我们需要创建出一
        //个新的response给应用层处理
        ResponseBody responseBody = response.peekBody(1024 * 1024);
        Log.d("ss",
                String.format("接收响应: [%s] %n返回json:【%s】 %.1fms %n%s",
                        response.request().url(),
                        responseBody.string(),
                        (t2 - t1) / 1e6d,
                        response.headers()
                ));
 
        } catch (JSONException e) {
            e.printStackTrace();
            
        }
         return response ;
     }
     
 }

 

 

 

方案3  :

使用系统自带  BufferedSource , response中的流会被关闭,程序会报错,我们需要创建出一   个新的response给应用层处理

 

public class WXTokenInterceptord implements Interceptor {
 
     private final String TAG = "wx";
 
     @Override
     public Response intercept(Chain chain) throws IOException {
          
                Request request = chain.request();
                Response response = chain.proceed(request);

                ResponseBody responseBody = response.body();
                long contentLength = responseBody.contentLength();

                if (!bodyEncoded(response.headers())) {
                    BufferedSource source = responseBody.source();
                    source.request(Long.MAX_VALUE); // Buffer the entire body.
                    Buffer buffer = source.buffer();

                    Charset charset = UTF8;
                    MediaType contentType = responseBody.contentType();
                    if (contentType != null) {
                        try {
                            charset = contentType.charset(UTF8);
                        } catch (UnsupportedCharsetException e) {
                            return response;
                        }
                    }

                    if (!isPlaintext(buffer)) {
                        return response;
                    }

                    if (contentLength != 0) {
                        String result = buffer.clone().readString(charset);
                        Constant.LogE(TAG, " response.url():"+ response.request().url());
                        Constant.LogE(TAG, " response.body():" + result);
                        //得到所需的string,开始判断是否异常
            

                    }

                }


                return response;
 
     }
     
 }

以上三种方案 是在okhttp的拦截器处理。还有另外一种方案是在 Retrofit 处理。连接:https://blog.csdn.net/sun6223508/article/details/102495779

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值