LoggerInterceptor.smali
.class public Lcom/zhy/http/okhttp/log/LoggerInterceptor;
.super Ljava/lang/Object;
.source "LoggerInterceptor.java"
# interfaces
.implements Lokhttp3/Interceptor;
# static fields
.field public static final TAG:Ljava/lang/String; = "OkHttpUtils"
# instance fields
.field private showResponse:Z
.field private tag:Ljava/lang/String;
# direct methods
.method public constructor <init>(Ljava/lang/String;)V
.registers 3
const/4 v0, 0x0
.line 38
invoke-direct {p0, p1, v0}, Lcom/zhy/http/okhttp/log/LoggerInterceptor;-><init>(Ljava/lang/String;Z)V
return-void
.end method
.method public constructor <init>(Ljava/lang/String;Z)V
.registers 4
.line 27
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 28
invoke-static {p1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v0
if-eqz v0, :cond_b
const-string p1, "OkHttpUtils"
.line 32
:cond_b
iput-boolean p2, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->showResponse:Z
.line 33
iput-object p1, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
return-void
.end method
.method private bodyToString(Lokhttp3/Request;)Ljava/lang/String;
.registers 3
.line 156
:try_start_0
invoke-virtual {p1}, Lokhttp3/Request;->newBuilder()Lokhttp3/Request$Builder;
move-result-object p1
invoke-virtual {p1}, Lokhttp3/Request$Builder;->build()Lokhttp3/Request;
move-result-object p1
.line 157
new-instance v0, Lokio/Buffer;
invoke-direct {v0}, Lokio/Buffer;-><init>()V
.line 158
invoke-virtual {p1}, Lokhttp3/Request;->body()Lokhttp3/RequestBody;
move-result-object p1
invoke-virtual {p1, v0}, Lokhttp3/RequestBody;->writeTo(Lokio/BufferedSink;)V
.line 159
invoke-virtual {v0}, Lokio/Buffer;->readUtf8()Ljava/lang/String;
move-result-object p1
:try_end_18
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_18} :catch_19
return-object p1
:catch_19
const-string p1, "something error when show requestBody."
return-object p1
.end method
.method private isText(Lokhttp3/MediaType;)Z
.registers 5
.line 136
invoke-virtual {p1}, Lokhttp3/MediaType;->type()Ljava/lang/String;
move-result-object v0
const/4 v1, 0x1
if-eqz v0, :cond_14
invoke-virtual {p1}, Lokhttp3/MediaType;->type()Ljava/lang/String;
move-result-object v0
const-string v2, "text"
invoke-virtual {v0, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_14
return v1
.line 140
:cond_14
invoke-virtual {p1}, Lokhttp3/MediaType;->subtype()Ljava/lang/String;
move-result-object v0
if-eqz v0, :cond_4b
.line 142
invoke-virtual {p1}, Lokhttp3/MediaType;->subtype()Ljava/lang/String;
move-result-object v0
const-string v2, "json"
invoke-virtual {v0, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_4a
invoke-virtual {p1}, Lokhttp3/MediaType;->subtype()Ljava/lang/String;
move-result-object v0
const-string v2, "xml"
invoke-virtual {v0, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_4a
invoke-virtual {p1}, Lokhttp3/MediaType;->subtype()Ljava/lang/String;
move-result-object v0
const-string v2, "html"
invoke-virtual {v0, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_4a
invoke-virtual {p1}, Lokhttp3/MediaType;->subtype()Ljava/lang/String;
move-result-object p1
const-string v0, "webviewhtml"
invoke-virtual {p1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result p1
if-eqz p1, :cond_4b
:cond_4a
return v1
:cond_4b
const/4 p1, 0x0
return p1
.end method
.method private logForRequest(Lokhttp3/Request;)V
.registers 7
.line 101
:try_start_0
invoke-virtual {p1}, Lokhttp3/Request;->url()Lokhttp3/HttpUrl;
move-result-object v0
invoke-virtual {v0}, Lokhttp3/HttpUrl;->toString()Ljava/lang/String;
move-result-object v0
.line 102
invoke-virtual {p1}, Lokhttp3/Request;->headers()Lokhttp3/Headers;
move-result-object v1
.line 104
iget-object v2, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
const-string v3, "========request\'log======="
invoke-static {v2, v3}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 105
iget-object v2, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "method : "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Lokhttp3/Request;->method()Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {v2, v3}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 106
iget-object v2, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "url : "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {v2, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
if-eqz v1, :cond_65
.line 107
invoke-virtual {v1}, Lokhttp3/Headers;->size()I
move-result v0
if-lez v0, :cond_65
.line 109
iget-object v0, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "headers : "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Lokhttp3/Headers;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 111
:cond_65
invoke-virtual {p1}, Lokhttp3/Request;->body()Lokhttp3/RequestBody;
move-result-object v0
if-eqz v0, :cond_b3
.line 114
invoke-virtual {v0}, Lokhttp3/RequestBody;->contentType()Lokhttp3/MediaType;
move-result-object v0
if-eqz v0, :cond_b3
.line 117
iget-object v1, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "requestBody\'s contentType : "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Lokhttp3/MediaType;->toString()Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-static {v1, v2}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 118
invoke-direct {p0, v0}, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->isText(Lokhttp3/MediaType;)Z
move-result v0
if-eqz v0, :cond_ac
.line 120
iget-object v0, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "requestBody\'s content : "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-direct {p0, p1}, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->bodyToString(Lokhttp3/Request;)Ljava/lang/String;
move-result-object p1
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {v0, p1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
goto :goto_b3
.line 123
:cond_ac
iget-object p1, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
const-string v0, "requestBody\'s content : maybe [file part] , too large too print , ignored!"
invoke-static {p1, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 127
:cond_b3
:goto_b3
iget-object p1, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
const-string v0, "========request\'log=======end"
invoke-static {p1, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
:try_end_ba
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_ba} :catch_ba
:catch_ba
return-void
.end method
.method private logForResponse(Lokhttp3/Response;)Lokhttp3/Response;
.registers 7
.line 55
:try_start_0
iget-object v0, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
const-string v1, "========response\'log======="
invoke-static {v0, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 56
invoke-virtual {p1}, Lokhttp3/Response;->newBuilder()Lokhttp3/Response$Builder;
move-result-object v0
.line 57
invoke-virtual {v0}, Lokhttp3/Response$Builder;->build()Lokhttp3/Response;
move-result-object v0
.line 58
iget-object v1, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "url : "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Lokhttp3/Response;->request()Lokhttp3/Request;
move-result-object v3
invoke-virtual {v3}, Lokhttp3/Request;->url()Lokhttp3/HttpUrl;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-static {v1, v2}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 59
iget-object v1, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "code : "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Lokhttp3/Response;->code()I
move-result v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-static {v1, v2}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 60
iget-object v1, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "protocol : "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Lokhttp3/Response;->protocol()Lokhttp3/Protocol;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-static {v1, v2}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 61
invoke-virtual {v0}, Lokhttp3/Response;->message()Ljava/lang/String;
move-result-object v1
invoke-static {v1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v1
if-nez v1, :cond_85
.line 62
iget-object v1, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "message : "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Lokhttp3/Response;->message()Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-static {v1, v2}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 64
:cond_85
iget-boolean v1, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->showResponse:Z
if-eqz v1, :cond_e7
.line 66
invoke-virtual {v0}, Lokhttp3/Response;->body()Lokhttp3/ResponseBody;
move-result-object v0
if-eqz v0, :cond_e7
.line 69
invoke-virtual {v0}, Lokhttp3/ResponseBody;->contentType()Lokhttp3/MediaType;
move-result-object v1
if-eqz v1, :cond_e7
.line 72
iget-object v2, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "responseBody\'s contentType : "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Lokhttp3/MediaType;->toString()Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {v2, v3}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 73
invoke-direct {p0, v1}, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->isText(Lokhttp3/MediaType;)Z
move-result v2
if-eqz v2, :cond_e0
.line 75
invoke-virtual {v0}, Lokhttp3/ResponseBody;->string()Ljava/lang/String;
move-result-object v0
.line 76
iget-object v2, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "responseBody\'s content : "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {v2, v3}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 78
invoke-static {v1, v0}, Lokhttp3/ResponseBody;->create(Lokhttp3/MediaType;Ljava/lang/String;)Lokhttp3/ResponseBody;
move-result-object v0
.line 79
invoke-virtual {p1}, Lokhttp3/Response;->newBuilder()Lokhttp3/Response$Builder;
move-result-object v1
invoke-virtual {v1, v0}, Lokhttp3/Response$Builder;->body(Lokhttp3/ResponseBody;)Lokhttp3/Response$Builder;
move-result-object v0
invoke-virtual {v0}, Lokhttp3/Response$Builder;->build()Lokhttp3/Response;
move-result-object p1
return-object p1
.line 82
:cond_e0
iget-object v0, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
const-string v1, "responseBody\'s content : maybe [file part] , too large too print , ignored!"
invoke-static {v0, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 88
:cond_e7
iget-object v0, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
const-string v1, "========response\'log=======end"
invoke-static {v0, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
:try_end_ee
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_ee} :catch_ee
:catch_ee
return-object p1
.end method
# virtual methods
.method public intercept(Lokhttp3/Interceptor$Chain;)Lokhttp3/Response;
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 44
invoke-interface {p1}, Lokhttp3/Interceptor$Chain;->request()Lokhttp3/Request;
move-result-object v0
.line 45
invoke-direct {p0, v0}, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->logForRequest(Lokhttp3/Request;)V
.line 46
invoke-interface {p1, v0}, Lokhttp3/Interceptor$Chain;->proceed(Lokhttp3/Request;)Lokhttp3/Response;
move-result-object p1
.line 47
invoke-direct {p0, p1}, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->logForResponse(Lokhttp3/Response;)Lokhttp3/Response;
move-result-object p1
return-object p1
.end method