日志拦截器
程序员文章站
2022-05-28 17:13:05
...
1.自定义一个类实现 Interceptor
package com.example.interceptor;
import android.util.Log;
import java.io.IOException;
import okhttp3.Interceptor;
import okhttp3.Request;
import okhttp3.Response;
import okhttp3.ResponseBody;
/**
* Created by 。 on 2018/12/20.
*/
public class LoggingInterceptor implements Interceptor {
@Override
public Response intercept(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);
Log.i("dt",String.format("接收响应: [%s] %n返回json:【%s】 %.1fms%n%s",
response.request().url(),
responseBody.string(),
(t2 - t1) / 1e6d,
response.headers()));
return response;
}
}
2.在你的工具类中写入以下方法
public static String get(String urlString){
OkHttpClient okHttpClient = new OkHttpClient.Builder()
.addInterceptor(new LoggingInterceptor())//日志拦截器
.connectTimeout(10, TimeUnit.SECONDS)//连接超时
.readTimeout(10,TimeUnit.SECONDS)//读取超时
.writeTimeout(10,TimeUnit.SECONDS)//写入超时
.build();
Request request = new Request.Builder().url(urlString).get().build();
try {
Response response = okHttpClient.newCall(request).execute();
String result = response.body().string();
Log.i("dt","请求结果:"+result);
return result;
} catch (IOException e) {
e.printStackTrace();
}
return "";
}
推荐阅读
-
struts2 18拦截器详解(十七)
-
logstash,nginx日志,grok pattern调试
-
python解析xml格式的日志文件
-
使用Flume+Kafka+SparkStreaming进行实时日志解析
-
SeasLog-1.5.3 发布,轻量高效的 PHP 日志扩展
-
Oracle错误日志:11gR2 RAC升级后启动报ORA-01565,ORA-17503,ORA-12547
-
php怎样使一篇日志原样输出解决办法
-
SQL Server中In-Flight日志究竟是多少
-
MySQL删除binlog日志及日志恢复数据的方法
-
[MySQLbinlog]彻底解析Mixed日志格式的binlog_MySQL