public class LoggingInterceptor implements Interceptor {
@Override
public Response intercept(Interceptor.Chain chain) throws IOException {
//这个chain里面包含了request和response,所以你要什么都可以从这里拿
Request request = chain.request();
long t1 = System.nanoTime();//请求发起的时间
Log.i("dt",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(1024 * 1024);
String string = responseBody.string();
Log.i("dt",String.format("接收响应: [%s] %n返回json:【%s】 %.1fms%n%s",
response.request().url(),
string,
(t2 - t1) / 1e6d,
response.headers()));
//这块直接ruturn就行,下面那两句话是我特殊使用
NetManager netManager = NetManager.getNetManager();
netManager.setJsonString(string);
return response;
}
}
Log日志请求拦截器
最新推荐文章于 2021-05-26 01:30:00 发布