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 static constructor <clinit>()V
.registers 1
return-void
.end method
.method public constructor <init>(Ljava/lang/String;)V
.registers 3
.param p1, "tag" # Ljava/lang/String;
.line 38
const/4 v0, 0x0
invoke-direct {p0, p1, v0}, Lcom/zhy/http/okhttp/log/LoggerInterceptor;-><init>(Ljava/lang/String;Z)V
.line 39
return-void
.end method
.method public constructor <init>(Ljava/lang/String;Z)V
.registers 4
.param p1, "tag" # Ljava/lang/String;
.param p2, "showResponse" # Z
.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
.line 30
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;
.line 34
return-void
.end method
.method private bodyToString(Lokhttp3/Request;)Ljava/lang/String;
.registers 5
.param p1, "request" # Lokhttp3/Request;
.line 156
:try_start_0
invoke-virtual {p1}, Lokhttp3/Request;->newBuilder()Lokhttp3/Request$Builder;
move-result-object v0
invoke-virtual {v0}, Lokhttp3/Request$Builder;->build()Lokhttp3/Request;
move-result-object v0
.line 157
.local v0, "copy":Lokhttp3/Request;
new-instance v1, Lokio/Buffer;
invoke-direct {v1}, Lokio/Buffer;-><init>()V
.line 158
.local v1, "buffer":Lokio/Buffer;
invoke-virtual {v0}, Lokhttp3/Request;->body()Lokhttp3/RequestBody;
move-result-object v2
invoke-virtual {v2, v1}, Lokhttp3/RequestBody;->writeTo(Lokio/BufferedSink;)V
.line 159
invoke-virtual {v1}, Lokio/Buffer;->readUtf8()Ljava/lang/String;
move-result-object v2
:try_end_18
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_18} :catch_19
return-object v2
.line 160
.end local v0 # "copy":Lokhttp3/Request;
.end local v1 # "buffer":Lokio/Buffer;
:catch_19
move-exception v0
.line 162
.local v0, "e":Ljava/io/IOException;
const-string/jumbo v1, "something error when show requestBody."
return-object v1
.end method
.method private isText(Lokhttp3/MediaType;)Z
.registers 5
.param p1, "mediaType" # Lokhttp3/MediaType;
.line 136
invoke-virtual {p1}, Lokhttp3/MediaType;->type()Ljava/lang/String;
move-result-object v0
const/4 v1, 0x1
if-eqz v0, :cond_15
invoke-virtual {p1}, Lokhttp3/MediaType;->type()Ljava/lang/String;
move-result-object v0
const-string/jumbo v2, "text"
invoke-virtual {v0, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_15
.line 138
return v1
.line 140
:cond_15
invoke-virtual {p1}, Lokhttp3/MediaType;->subtype()Ljava/lang/String;
move-result-object v0
if-eqz v0, :cond_4e
.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_4d
invoke-virtual {p1}, Lokhttp3/MediaType;->subtype()Ljava/lang/String;
move-result-object v0
const-string/jumbo v2, "xml"
invoke-virtual {v0, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_4d
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_4d
invoke-virtual {p1}, Lokhttp3/MediaType;->subtype()Ljava/lang/String;
move-result-object v0
const-string/jumbo v2, "webviewhtml"
invoke-virtual {v0, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_4e
.line 147
:cond_4d
return v1
.line 149
:cond_4e
const/4 v0, 0x0
return v0
.end method
.method private logForRequest(Lokhttp3/Request;)V
.registers 9
.param p1, "request" # Lokhttp3/Request;
.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
.local v0, "url":Ljava/lang/String;
invoke-virtual {p1}, Lokhttp3/Request;->headers()Lokhttp3/Headers;
move-result-object v1
.line 104
.local v1, "headers":Lokhttp3/Headers;
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/jumbo 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 v3
invoke-static {v2, v3}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 107
if-eqz v1, :cond_66
invoke-virtual {v1}, Lokhttp3/Headers;->size()I
move-result v2
if-lez v2, :cond_66
.line 109
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, "headers : "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Lokhttp3/Headers;->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 111
:cond_66
invoke-virtual {p1}, Lokhttp3/Request;->body()Lokhttp3/RequestBody;
move-result-object v2
.line 112
.local v2, "requestBody":Lokhttp3/RequestBody;
if-eqz v2, :cond_b7
.line 114
invoke-virtual {v2}, Lokhttp3/RequestBody;->contentType()Lokhttp3/MediaType;
move-result-object v3
.line 115
.local v3, "mediaType":Lokhttp3/MediaType;
if-eqz v3, :cond_b7
.line 117
iget-object v4, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
new-instance v5, Ljava/lang/StringBuilder;
invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v6, "requestBody\'s contentType : "
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Lokhttp3/MediaType;->toString()Ljava/lang/String;
move-result-object v6
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v5
invoke-static {v4, v5}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 118
invoke-direct {p0, v3}, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->isText(Lokhttp3/MediaType;)Z
move-result v4
if-eqz v4, :cond_af
.line 120
iget-object v4, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
new-instance v5, Ljava/lang/StringBuilder;
invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v6, "requestBody\'s content : "
invoke-virtual {v5, v6}, 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 v6
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v5
invoke-static {v4, v5}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
goto :goto_b7
.line 123
:cond_af
iget-object v4, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
const-string/jumbo v5, "requestBody\'s content : maybe [file part] , too large too print , ignored!"
invoke-static {v4, v5}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 127
.end local v3 # "mediaType":Lokhttp3/MediaType;
:cond_b7
:goto_b7
iget-object v3, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
const-string v4, "========request\'log=======end"
invoke-static {v3, v4}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
:try_end_be
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_be} :catch_c0
.line 131
nop
.end local v0 # "url":Ljava/lang/String;
.end local v1 # "headers":Lokhttp3/Headers;
.end local v2 # "requestBody":Lokhttp3/RequestBody;
goto :goto_c1
.line 128
:catch_c0
move-exception v0
.line 132
:goto_c1
return-void
.end method
.method private logForResponse(Lokhttp3/Response;)Lokhttp3/Response;
.registers 10
.param p1, "response" # Lokhttp3/Response;
.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
.local v0, "builder":Lokhttp3/Response$Builder;
invoke-virtual {v0}, Lokhttp3/Response$Builder;->build()Lokhttp3/Response;
move-result-object v1
.line 58
.local v1, "clone":Lokhttp3/Response;
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/jumbo v4, "url : "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Lokhttp3/Response;->request()Lokhttp3/Request;
move-result-object v4
invoke-virtual {v4}, Lokhttp3/Request;->url()Lokhttp3/HttpUrl;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)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 59
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, "code : "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Lokhttp3/Response;->code()I
move-result v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(I)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 60
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/jumbo v4, "protocol : "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Lokhttp3/Response;->protocol()Lokhttp3/Protocol;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)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 61
invoke-virtual {v1}, Lokhttp3/Response;->message()Ljava/lang/String;
move-result-object v2
invoke-static {v2}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v2
if-nez v2, :cond_87
.line 62
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, "message : "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Lokhttp3/Response;->message()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 64
:cond_87
iget-boolean v2, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->showResponse:Z
if-eqz v2, :cond_ed
.line 66
invoke-virtual {v1}, Lokhttp3/Response;->body()Lokhttp3/ResponseBody;
move-result-object v2
.line 67
.local v2, "body":Lokhttp3/ResponseBody;
if-eqz v2, :cond_ed
.line 69
invoke-virtual {v2}, Lokhttp3/ResponseBody;->contentType()Lokhttp3/MediaType;
move-result-object v3
.line 70
.local v3, "mediaType":Lokhttp3/MediaType;
if-eqz v3, :cond_ed
.line 72
iget-object v4, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
new-instance v5, Ljava/lang/StringBuilder;
invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v6, "responseBody\'s contentType : "
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Lokhttp3/MediaType;->toString()Ljava/lang/String;
move-result-object v6
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v5
invoke-static {v4, v5}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 73
invoke-direct {p0, v3}, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->isText(Lokhttp3/MediaType;)Z
move-result v4
if-eqz v4, :cond_e5
.line 75
invoke-virtual {v2}, Lokhttp3/ResponseBody;->string()Ljava/lang/String;
move-result-object v4
.line 76
.local v4, "resp":Ljava/lang/String;
iget-object v5, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v7, "responseBody\'s content : "
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v6, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v6
invoke-static {v5, v6}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 78
invoke-static {v3, v4}, Lokhttp3/ResponseBody;->create(Lokhttp3/MediaType;Ljava/lang/String;)Lokhttp3/ResponseBody;
move-result-object v5
move-object v2, v5
.line 79
invoke-virtual {p1}, Lokhttp3/Response;->newBuilder()Lokhttp3/Response$Builder;
move-result-object v5
invoke-virtual {v5, v2}, Lokhttp3/Response$Builder;->body(Lokhttp3/ResponseBody;)Lokhttp3/Response$Builder;
move-result-object v5
invoke-virtual {v5}, Lokhttp3/Response$Builder;->build()Lokhttp3/Response;
move-result-object v5
return-object v5
.line 82
.end local v4 # "resp":Ljava/lang/String;
:cond_e5
iget-object v4, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
const-string/jumbo v5, "responseBody\'s content : maybe [file part] , too large too print , ignored!"
invoke-static {v4, v5}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 88
.end local v2 # "body":Lokhttp3/ResponseBody;
.end local v3 # "mediaType":Lokhttp3/MediaType;
:cond_ed
iget-object v2, p0, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->tag:Ljava/lang/String;
const-string v3, "========response\'log=======end"
invoke-static {v2, v3}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
:try_end_f4
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_f4} :catch_f6
.line 92
nop
.end local v0 # "builder":Lokhttp3/Response$Builder;
.end local v1 # "clone":Lokhttp3/Response;
goto :goto_f7
.line 89
:catch_f6
move-exception v0
.line 94
:goto_f7
return-object p1
.end method
# virtual methods
.method public intercept(Lokhttp3/Interceptor$Chain;)Lokhttp3/Response;
.registers 5
.param p1, "chain" # Lokhttp3/Interceptor$Chain;
.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
.local v0, "request":Lokhttp3/Request;
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 v1
.line 47
.local v1, "response":Lokhttp3/Response;
invoke-direct {p0, v1}, Lcom/zhy/http/okhttp/log/LoggerInterceptor;->logForResponse(Lokhttp3/Response;)Lokhttp3/Response;
move-result-object v2
return-object v2
.end method