Retrofit使用Log攔截器在控制臺輸出Log

一、使用自定義Log攔截器

1、創(chuàng)建自定義Log攔截器類

class LoggingInterceptor implements Interceptor {
    @Override
    public Response intercept(Chain chain) throws IOException {
        //這個chain里面包含了request和response,所以你要什么都可以從這里拿
        Request request = chain.request();
        long t1 = System.nanoTime();//請求發(fā)起的時間

        String method = request.method();
        if ("POST".equals(method)) {
            StringBuilder sb = new StringBuilder();
            if (request.body() instanceof FormBody) {
                FormBody body = (FormBody) request.body();
                for (int i = 0; i < body.size(); i++) {
                    sb.append(body.encodedName(i) + "=" + body.encodedValue(i) + ",");
                }
                sb.delete(sb.length() - 1, sb.length());
                Log.d("CSDN_LQR",String.format("發(fā)送請求 %s on %s %n%s %nRequestParams:{%s}",
                        request.url(), chain.connection(), request.headers(), sb.toString()));
            }
        } else {
            Log.d("CSDN_LQR",String.format("發(fā)送請求 %s on %s%n%s",
                    request.url(), chain.connection(), request.headers()));
        }
        Response response = chain.proceed(request);
        long t2 = System.nanoTime();//收到響應(yīng)的時間
        //這里不能直接使用response.body().string()的方式輸出日志
        //因為response.body().string()之后,response中的流會被關(guān)閉,程序會報錯,我們需要創(chuàng)建出一
        //個新的response給應(yīng)用層處理
        ResponseBody responseBody = response.peekBody(1024 * 1024);
        Log.d("CSDN_LQR",
                String.format("接收響應(yīng): [%s] %n返回json:【%s】 %.1fms %n%s",
                        response.request().url(),
                        responseBody.string(),
                        (t2 - t1) / 1e6d,
                        response.headers()
                ));
        return response;
    }
}

2、使用Log攔截器

OkHttpClient.Builder builder = new OkHttpClient.Builder();
if (BuildConfig.DEBUG) {
    builder.addInterceptor(new LoggingInterceptor());//使用自定義的Log攔截器
}

OkHttpClient client = builder.build();
mRetrofit = new Retrofit.Builder()
        ...
        .client(client)
        .build();

二、使用okhttp官方Log攔截器

1、引入依賴

compile 'com.squareup.okhttp3:logging-interceptor:3.3.1'

2、使用Log攔截器

OkHttpClient.Builder builder = new OkHttpClient.Builder();
if (BuildConfig.DEBUG) {
    // Log信息攔截器
    HttpLoggingInterceptor loggingInterceptor = new HttpLoggingInterceptor();
    loggingInterceptor.setLevel(HttpLoggingInterceptor.Level.BODY);//這里可以選擇攔截級別

    //設(shè)置 Debug Log 模式
    builder.addInterceptor(loggingInterceptor);
}

OkHttpClient client = builder.build();
mRetrofit = new Retrofit.Builder()
        ...
        .client(client)
        .build();

使用上述兩種Log攔截器設(shè)置方式中的任意一種之后,當(dāng)使用debug模式運行項目時,在控制臺中就會打印出每次客戶端發(fā)出的請求和收到的響應(yīng)內(nèi)容了。

歡迎關(guān)注微信公眾號:全棧行動
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容