android自定义拦截器,Android开发Retrofit使用Log拦截器在控制台输出Log

本文介绍了如何在Android开发中使用Retrofit集成自定义和官方提供的Log拦截器,以在控制台输出请求和响应详情。在自定义拦截器中,详细展示了如何处理POST请求和响应,而在官方Log拦截器中则演示了不同级别的日志打印。通过这些方法,开发者可以在调试模式下轻松查看网络请求的交互信息。

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

释放双眼,带上耳机,听听看~!

一、使用自定义Log拦截器

1、创建自定义Log拦截器类

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("优快云_LQR",String.format("发送请求 %s on %s %n%s %nRequestParams:{%s}",

request.url(), chain.connection(), request.headers(), sb.toString()));

}

} else {

Log.d("优快云_LQR",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.d("优快云_LQR",

String.format("接收响应: [%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);//这里可以选择拦截级别

//设置 Debug Log 模式

builder.addInterceptor(loggingInterceptor);

}

OkHttpClient client = builder.build();

mRetrofit = new Retrofit.Builder()

...

.client(client)

.build();

使用上述两种Log拦截器设置方式中的任意一种之后,当使用debug模式运行项目时,在控制台中就会打印出每次客户端发出的请求和收到的响应内容了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值