参考:Interceptors 中文翻译:Okhttp-wiki 之 Interceptors 拦截器
class LoggingInterceptor implements Interceptor { @Override public Response intercept(Chain chain) throws IOException { //这个chain里面包含了request和response,所以你要什么都可以从这里拿 Request request = chain.request(); long t1 = System.nanoTime();//请求发起的时间 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("123===",String.format("发送请求 %s on %s %n%s %nRequestParams:{%s}", request.url(), chain.connection(), request.headers(), sb.toString())); } } else { Log.d("123===",String.format("发送请求 %s on %s %n%s", request.url(), chain.connection(), request.headers())); } Response response = chain.proceed(request); long t2 = System.nanoTime();//收到响应的时间 //这里不能直接使用response.body().string()的方式输出日志 /*因为response.body().string()之后,response中的流会被关闭,程序会报错,我们需要创建出一个新的response给应用层处理*/ ResponseBody responseBody = response.peekBody(response.body().contentLength()); Log.d("123===", String.format("接收响应: [%s] %n返回json:[%s] %.1fms %n%s", response.request().url(), responseBody.string(), (t2 - t1) / 1e6d, response.headers() )); return response; } }