当前位置: 移动技术网 > IT编程>移动开发>Android > Retrofit2日志拦截器的使用

Retrofit2日志拦截器的使用

2019年08月01日  | 移动技术网IT编程  | 我要评论

挽留txt下载,奸妃唔易做,徐筠老公

显示样式如下,复制内容的时候使用鼠标中键进行选中

打印内容:code,请求方式,url,请求头,请求体,返回json

class loggerinterceptor : interceptor {
 override fun intercept(chain: interceptor.chain?): response {
 val orgrequest = chain!!.request()
 val response = chain.proceed(orgrequest)
 val body = orgrequest.body()
 val sb = stringbuilder()
 if (orgrequest.method() == "post" && body is formbody) {
  val body1 = body
  for (i in 0 until body1.size()) {
  sb.append(body1.encodedname(i) + "=" + body1.encodedvalue(i) + ",")
  }
  sb.delete(sb.length - 1, sb.length)
  //打印post请求的信息
  logger.t(appconfigs.logger_net_tag).d("code=" + response.code() + "|method=" + orgrequest.method() + "|url=" + orgrequest.url()
   + "\n" + "headers:" + orgrequest.headers().tomultimap()
   + "\n" + "post请求体:{" + sb.tostring() + "}")
 } else {
  //打印get请求的信息
  logger.t(appconfigs.logger_net_tag).d("code=" + response.code() + "|method=" + orgrequest.method() + "|url=" + orgrequest.url()
   + "\n" + "headers:" + orgrequest.headers().tomultimap())
 }
 //返回json
 val responsebody = response.body()
 val contentlength = responsebody!!.contentlength()
  val source = responsebody.source()
  source.request(java.lang.long.max_value)
  val buffer = source.buffer()
  var charset = utf8
  val contenttype = responsebody.contenttype()
  if (contenttype != null) {
  try {
   charset = contenttype.charset(utf8)
  } catch (e: unsupportedcharsetexception) {
   return response
  }

  }
  if (contentlength != 0l) {
  //打印返回json
  //json日志使用鼠标中键进行选中
  logger.t(appconfigs.logger_net_tag).json(buffer.clone().readstring(charset))
  }
 return response
 }

}

在application中进行初始化logger

val strategy = prettyformatstrategy.newbuilder()
  .showthreadinfo(false) // 是否显示线程信息,默认为ture
  .methodcount(1)  // 显示的方法行数
  .methodoffset(0) // 隐藏内部方法调用到偏移量
  .tag("tag")
  .build()
 logger.addlogadapter(object : androidlogadapter(strategy) {
  override fun isloggable(priority: int, tag: string?): boolean {
  return buildconfig.debug
  }
 })

除了需要依赖retrofit2相关依赖外还需要依赖

implementation 'com.orhanobut:logger:2.2.0'

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网