OkHttp日志拦截器打印

本文介绍如何在OkHttp中配置和使用日志拦截器,详细讲解了设置日志拦截器的步骤,以便在应用中打印HTTP请求和响应的详细信息,帮助开发者进行调试和问题排查。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

public class LogInterceptor implements Interceptor {
    public static String TAG = "LogInterceptor";
    @Override
    public Response intercept(Interceptor.Chain chain) throws IOException {
        Request request = chain.request();
        long startTime = System.currentTimeMillis();
        Response response = chain.proceed(chain.request());
        long endTime = System.currentTimeMillis();
        long duration=endTime-startTime;
        MediaType mediaType = response.body().contentType();
        String content = response.body().string();
        Log.d(TAG,"\n");
        Log.d(TAG,"----------Start----------------");
        Log.d(TAG, "| "+request.toString());
        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(TAG, "| RequestParams:{"+sb.toString()+"}");
            }
        }
        Log.d(TAG, "| Response:" + content);
        Log.d(TAG,"----------End:"+duration+"毫秒----------");
        return response.newBuilder()
                .body(ResponseBody.create(mediaType, content))
                .build();
    }

}

公共参数

/**
 * author: 17826
 * created on: 2018/12/05 14:30
 * description: 自定义拦截器,用于封装公用参数
 */
public class MyInterceptor implements Interceptor {

    @NonNull
    @Override
    public Response intercept(@NonNull Chain chain) throws IOException {

        //获取原始的Request请求
        Request request = chain.request();

        SharedPreferences sharedPreferences = FrescoApplication.mContext.getSharedPreferences("kk", 0);
        String userId = sharedPreferences.getString("userId", "");
        String sessionId = sharedPreferences.getString("sessionId", "");

        //如果有一个为空,不用添加请求头
        if (TextUtils.isEmpty(userId) || TextUtils.isEmpty(sessionId)) {
            return chain.proceed(request);
        }

        Request build = request.newBuilder()
                .addHeader("userId", userId)
                .addHeader("sessionId", sessionId)
                .build();
        return chain.proceed(build);

        /*//获取请求方法
        String method = request.method();

        *//* 不用method.equals("GET")的原因:
         * method有可能为null,会造成的空指针异常 *//*
        //判断请求的类型
        if ("GET".equals(method)) {
            HttpUrl httpUrl = request.url()
                    .newBuilder()
                    .addQueryParameter(PARAMETER_NAME, PARAMETER_VALUE)
                    .build();
            //获取添加公共参数之后的Request对象
            request = new Request.Builder().url(httpUrl)
                    .build();
        } else if ("POST".equals(method)) {
            RequestBody body = request.body();

            if (body instanceof FormBody) {
                FormBody.Builder builder = new FormBody.Builder();

                //获取原来Request中的参数
                FormBody originalFormBody = (FormBody)body;
                //遍历添加到新FormBody中
                for (int i = 0; i < originalFormBody.size(); i++) {
                    builder.add(originalFormBody.name(i), originalFormBody.value(i));
                }
                //添加公共参数
                builder.add(PARAMETER_NAME, PARAMETER_VALUE);
                FormBody formBody = builder.build();

                //获取添加公共参数之后的Request对象
                request = request.newBuilder()
                        .post(formBody)
                        .build();
            }
        }
        //发送拼接完后的请求
        return chain.proceed(request);*/
    }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值