Android OkHttp3中HttpLoggingInterceptor使用

目录

    • [一 概述](#一 概述)
      • [1.1 日志级别](#1.1 日志级别)
    • [二 使用](#二 使用)
      • [2.1 引入依赖](#2.1 引入依赖)
      • [2.2 创建对象](#2.2 创建对象)
      • [2.3 添加拦截器](#2.3 添加拦截器)
    • [三 结果展示](#三 结果展示)
      • [3.1 日志级别为BODY](#3.1 日志级别为BODY)
      • [3.2 日志级别为BASIC](#3.2 日志级别为BASIC)
      • [3.3 日志级别为HEADERS](#3.3 日志级别为HEADERS)
    • 参考

一 概述

HttpLoggingInterceptor是OkHttp3提供的拦截器,用来记录HTTP请求和响应的详细信息。

1.1 日志级别

  • BODY
    记录请求和响应的头部信息、body内容,以及BASIC级别的信息。注意,记录body内容可能会消耗资源,并且会读取body数据,这可能会影响请求的执行。
  • BASIC
    记录请求类型、URL、响应状态码以及响应时间。
  • HEADERS
    记录请求和响应的头部信息,以及BASIC级别的信息。
  • NONE
    不记录任何日志。

二 使用

2.1 引入依赖

groovy 复制代码
implementation 'com.squareup.okhttp3:okhttp:4.9.0'
implementation 'com.squareup.okhttp3:logging-interceptor:4.9.1'

2.2 创建对象

kotlin 复制代码
val logInterceptor =  HttpLoggingInterceptor {
    message -> Log.d("retrofit", message)
}.apply {
    level = HttpLoggingInterceptor.Level.BODY
}

2.3 添加拦截器

kotlin 复制代码
 private val okHttpClient: OkHttpClient
        get() =OkHttpClient.Builder()
            //日志拦截器
            .addInterceptor(logInterceptor)
            //请求超时时间
            .connectTimeout(TIME_OUT_SECONDS,TimeUnit.SECONDS)
            .build()

三 结果展示

3.1 日志级别为BODY

3.2 日志级别为BASIC

3.3 日志级别为HEADERS

参考

https://blog.csdn.net/weixin_37477009/article/details/136142311

相关推荐
独泪了无痕5 小时前
使用Fetch API 探索前后端数据交互
前端·http·交互设计
北京耐用通信7 小时前
协议融合的工业钥匙:耐达讯自动化网关如何打通CC-Link IE转DeviceNet的通信壁垒
人工智能·物联网·网络协议·自动化·信息与通信
9 小时前
深度解析Compose中的BoxWithConstraints
android·kotlin·android jetpack
jolimark9 小时前
MySQL--》如何在MySQL中打造高效优化索引
android·mysql·adb
book123_0_999 小时前
【MySQL】MySQL函数之JSON_EXTRACT
android·mysql·json
冬奇Lab10 小时前
ContentProvider与Uri权限:跨应用数据共享
android·源码阅读
峥嵘life10 小时前
Android16 【GTS】 GtsDevicePolicyTestCases 测试存在Failed项
android·linux·学习
IP搭子来一个10 小时前
静态独享IP是什么?在数据采集任务中有哪些作用?
网络·网络协议·tcp/ip
aqi0010 小时前
【送书活动】《鸿蒙HarmonyOS 6:应用开发从零基础到App上线》迎新送书啦
android·华为·harmonyos·鸿蒙
符哥200810 小时前
基于 OkHttp+Retrofit 实现 JSON / 表单 / XML/Protobuf 数据格式全解析
okhttp·json·retrofit