Okhttp设置请求日志过滤器,支持打印Post请求参数
来源:互联网 发布:2017杭州程序员招聘 编辑:程序博客网 时间:2024/05/06 11:58
在网络请求的时候我们一般会打印日志,包含请求地址、请求参数、返回结果、请求耗时等。
在之前的操作中,可能会,在Request执行的时候打印一下,Response返回结果的时候打印一下。那么这样在如果同时多个请求的情况下就会产生混乱,日志里会出现并列多个请求,并列多个结果。那么使用Okhttp的过滤器便能解决这一问题
代码如下:
public class LogInterceptor implements Interceptor { public static String TAG = "LogInterceptor"; @Override public okhttp3.Response intercept(Chain chain) throws IOException { Request request = chain.request(); long startTime = System.currentTimeMillis(); okhttp3.Response response = chain.proceed(chain.request()); long endTime = System.currentTimeMillis(); long duration=endTime-startTime; okhttp3.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(okhttp3.ResponseBody.create(mediaType, content)) .build(); }}
Get和Post是两种常见的请求方式,网上很多文章只是说明了打印请求地址,在Get请求时候这个参数会拼接在请求地址后面,而Post请求的参数是在请求体里面的,因此必需要先获取到请求体然后遍历,拿到请求参数。因此上面代码中的这部分是为了打印Post请求参数而来。
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()+"}"); } }
具体过滤器使用方式很简单在实例化httpClient的时候addInterceptor即可:
OkHttpClient httpClient = new OkHttpClient.Builder().addInterceptor(new LogInterceptor()) .connectTimeout(10, TimeUnit.SECONDS) .readTimeout(10, TimeUnit.SECONDS) .writeTimeout(10, TimeUnit.SECONDS) .retryOnConnectionFailure(false) .build();
据说要配个图才好看
0 0
- Okhttp设置请求日志过滤器,支持打印Post请求参数
- 过滤器 打印请求日志
- tomcat的acess_log打印post请求参数,分析日志
- okhttp GET请求 post请求
- OkHttp Get请求/Post请求
- OKhttp post请求
- okHttp post&get请求
- OkHttp Post请求方式
- Okhttp POST请求
- okhttp的post请求
- OkHttp getand post 请求
- okhttp get post请求
- okhttp 登录post请求
- okhttp post请求
- 让nginx日志支持记录POST请求
- post网络请求,支持多层字典参数
- 解决spring设置filter过滤器结合rest风格获取post请求body参数输入流问题
- Okhttp的Post请求参数在Interceptor中修改
- hdu 3032 Nim or not Nim? (Multi-SG函数)
- XML中的standalone什么意思?
- tensorflow学习笔记(二十六):构建TF代码
- ①协方差、相关系数(皮尔逊相关系数),等同于:内积、余弦值。
- ORA-38171: Insufficient privileges for SQL management object operation
- Okhttp设置请求日志过滤器,支持打印Post请求参数
- [嵌入式]异常与中断(上)
- window.requestAnimationFrame()的使用
- js贪吃蛇
- 简单理解Ajax
- maven设置默认jdk
- 京东量化教你如何用简单的策略回测盈利
- Cursor.moveToNext顺序问题?
- 《JavaScript语言精粹》