由于LogCat日志可读性差, 所以Net支持以下两种方案
1. 使用AndroidStudio的[Profiler](https://developer.android.com/studio/profile/network-profiler?hl=zh-cn)监听网络
- 可以查看项目所有OkHttp框架发起的网络请求
- 网络请求是动态曲线图, 查不太方便
- 启动应用时立刻触发的请求无法捕捉
2. 安装[Okhttp Profiler](https://github.com/itkacher/OkHttpProfiler)插件 (推荐)
- 列表显示请求
- 要求添加Net的`LogRecordInterceptor`拦截器
- 实际上是插件捕获logCat生成的日志, 线上环境需要关闭
## 添加日志拦截器
```kotlin hl_lines="2"
NetConfig.initialize("https://github.com/liangjingkanji/Net/", this) {
addInterceptor(LogRecordInterceptor(BuildConfig.DEBUG))
}
```
| 构造参数 | 描述 |
|-|-|
| enabled | 是否启用日志 |
| requestByteCount | 请求日志信息最大字节数, 默认1MB |
| responseByteCount | 响应日志信息最大字节数, 默认4MB |
这样会可以在LogCat看到日志输出, 但是我们要使用插件预览就需要第 2 步
## 安装插件
### 1. 安装插件
在插件市场搜索: "`Okhttp Profiler`"
### 2. 打开窗口
安装以后在AndroidStudio右下角打开窗口
> 请在每次使用前都先打开插件窗口, 如果有延迟或者不显示就反复打开下窗口
使用效果
| 标题 | 描述 |
|-|-|
| Device | 选择调试设备 |
| Process | 选择展示记录的进程 |
|
抓取 | 一般情况不需要使用, 假设没有及时更新请点击图标 |
|
清空 | 清空记录 |
## 自定义日志(解密)
通过继承`LogRecordInterceptor`可以覆写函数自定义自己的日志输出逻辑
1. 如果你的请求体是被加密的内容, 你可以通过覆写`requestString`函数返回解密后的请求信息
2. 如果你的响应体是被加密的内容, 你可以通过覆写`responseString`函数返回解密后的响应信息
然后初始化时添加自己实现拦截器即可
```kotlin
NetConfig.initialize("https://github.com/liangjingkanji/Net/", this) {
addInterceptor(MyLogRecordInterceptor(BuildConfig.DEBUG))
}
```
## LogCat过滤
实际上Net的网络日志还是会被打印到LogCat, 然后通过插件捕捉显示.
如果不想LogCat的冗余日志影响查看其它日志, 可以通过AndroidStudio的功能折叠隐藏, 添加一个`OKPREL_`过滤字段即可
## 其他网络框架
可能你项目中还残留其他网络框架, 也可以使用Net的日志记录器`LogRecorder`来为其他框架打印日志信息. 如果是基于OkHttp的框架那可以直接使用LogRecordInterceptor
| 函数 | 描述 |
|-|-|
| generateId | 产生一个唯一标识符, 用于判断为同一网络请求 |
| recordRequest | 记录请求信息 |
| recordResponse | 记录响应信息 |
| recordException | 记录请求异常信息 |