以下两种日志插件
Okhttp Profiler | Profiler |
---|---|
列表显示 | 动态曲线图 |
添加LogRecordInterceptor 拦截器 |
默认记录所有OkHttp的请求 |
原理是插件捕获LogCat日志, 线上环境需关闭 | 无法捕获启动一瞬间的请求 |
添加日志拦截器
NetConfig.initialize(Api.HOST, this) {
addInterceptor(LogRecordInterceptor(BuildConfig.DEBUG))
}
| 构造参数 | 描述 | |-|-| | enabled | 是否启用日志 | | requestByteCount | 请求日志信息最大字节数, 默认1MB | | responseByteCount | 响应日志信息最大字节数, 默认4MB |
此时仅LogCat输出日志, 要预览请安装插件
在插件市场搜索: "Okhttp Profiler
"
安装以后在AndroidStudio右下角打开窗口
!!! warning "不显示日志"
请在请求前确保有打开过插件窗口, 如果依然不显示可以反复打开/关闭窗口
每次AS更新可能要该插件作者适配, 发现无效请[反馈给作者更新](https://github.com/itkacher/OkHttpProfiler/issues)
使用效果
| 标题 | 描述 |
|-|-|
| Device | 选择调试设备 |
| Process | 选择展示记录的进程 |
| 抓取 | 一般情况不需要使用, 假设没有及时更新请点击图标 |
|
清空 | 清空记录 |
继承LogRecordInterceptor
复写函数实现自定义
getRequestLog
返回请求参数getResponseLog
返回响应参数初始化时添加自己的拦截器
NetConfig.initialize(Api.HOST, this) {
addInterceptor(MyLogRecordInterceptor(BuildConfig.DEBUG))
}
不想网络日志影响其他日志查看, 可以添加OKPREL_
为日志折叠规则
LogRecordInterceptor
属于OkHttp拦截器, 其他网络请求框架也可以使用
或者直接使用LogRecorder
输出日志
| LogRecorder | 描述 | |-|-| | generateId | 产生一个唯一标识符, 用于判断为同一网络请求 | | recordRequest | 记录请求信息 | | recordResponse | 记录响应信息 | | recordException | 记录请求异常信息 |