2017-01-18 7 views
2

OkHttpClientに2つのInteceptorとNetworkInceptorを追加しますが、cachingInterceptorだけが動作します。別のインターセプターを追加してリクエストヘッダーを変更する方法がわかりません。なぜokhttp3.Interceptorが機能しないのですか?

また、リクエストヘッダーがコードの下で変更されていないことを示す画像があります。

import android.app.Application; 

import com.google.gson.Gson; 
import com.google.gson.GsonBuilder; 
import com.orhanobut.logger.Logger; 

import java.io.IOException; 

import javax.inject.Singleton; 

import dagger.Module; 
import dagger.Provides; 
import me.strugglingvincent.meizhichinese.NetworkApi; 
import me.strugglingvincent.meizhichinese.Util.ConnectionUtil; 
import okhttp3.Cache; 
import okhttp3.Headers; 
import okhttp3.HttpUrl; 
import okhttp3.Interceptor; 
import okhttp3.OkHttpClient; 
import okhttp3.Request; 
import okhttp3.Response; 
import okhttp3.logging.HttpLoggingInterceptor; 
import retrofit2.Retrofit; 
import retrofit2.adapter.rxjava.RxJavaCallAdapterFactory; 
import retrofit2.converter.gson.GsonConverterFactory; 
import rx.Scheduler; 
import rx.schedulers.Schedulers; 

/** 
* NetModule Object 
* Created by StrugglingVincent on 12/08/2016. 
*/ 
@Module 
public class NetModule { 

private final String mBaseUrl; 

public NetModule() { 
    mBaseUrl = "https://wtf.herokuapp.com/wtf/"; 
} 

@Provides 
@Singleton 
NetworkApi provideNetworkApi(Retrofit retrofit) { 
    return retrofit.create(NetworkApi.class); 
} 


@Provides 
@Singleton 
OkHttpClient provideOkHttpClient(Cache cache, Interceptor cachingInterceptor) { 
    OkHttpClient.Builder builder = new OkHttpClient.Builder(); 
    builder.addInterceptor(cachingInterceptor);    //It works 
    builder.addInterceptor(new Interceptor() {    //It doesn't work 
     @Override 
     public Response intercept(Chain chain) throws IOException { 
      Request request = chain.request() 
        .newBuilder() 
        .addHeader("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8") 
        .addHeader("Accept-Encoding", "gzip, deflate") 
        .addHeader("Connection", "keep-alive") 
        .addHeader("Accept", "*/*") 
        .addHeader("Cookie", "add cookies here") 
        .addHeader("Referer","http://www.baidu.com") 
        .build(); 
      System.out.println("interceptor:"+request.headers()); 
      return chain.proceed(request); 
     } 
    }); 
    builder.addNetworkInterceptor(new Interceptor() {  //It doesn't work 
     @Override 
     public Response intercept(Chain chain) throws IOException { 
      Request request = chain.request() 
        .newBuilder() 
        .addHeader("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8") 
        .addHeader("Accept-Encoding", "gzip, deflate") 
        .addHeader("Connection", "keep-alive") 
        .addHeader("Accept", "*/*") 
        .addHeader("Cookie", "add cookies here") 
        .addHeader("Referer","http://www.baidu.com") 
        .build(); 
      System.out.println("network:"+request.headers()); 
      return chain.proceed(request); 
     } 
    }); 
    builder.cache(cache); 
    return builder.build(); 
} 

@Provides 
@Singleton 
Cache provideCache(Application application) { 
    int cacheSize = 10 * 1024 * 1024;//10 mb 
    return new Cache(application.getCacheDir(), cacheSize); 
} 

@Provides 
@Singleton 
    Retrofit provideRetrofit(OkHttpClient okHttpClient, GsonConverterFactory gsonConverterFactory) { 
    System.out.println("shenmjibawanyier?"+okHttpClient!=null); 
    System.out.println("fdsja;lfsjkl;"+okHttpClient.interceptors()); 
    System.out.println("wfewajfewafewea"+okHttpClient.networkInterceptors()); 
    Retrofit.Builder retrofitBuilder = new Retrofit.Builder(); 
    retrofitBuilder.baseUrl(mBaseUrl) 
      .client(okHttpClient) 
      .addConverterFactory(gsonConverterFactory) 
      .addCallAdapterFactory(RxJavaCallAdapterFactory.create()); 
    return retrofitBuilder.build(); 
} 

@Provides 
@Singleton 
GsonConverterFactory provideGsonFactory() { 
    Gson gson = new GsonBuilder().setDateFormat("yyyy-MM-dd'T'HH:mm:ss'Z'").create(); 
    return GsonConverterFactory.create(gson); 
} 

/** 
* Log Network Response 
* 
* @return Logging Interceptor 
*/ 
@Provides 
@Singleton 
HttpLoggingInterceptor getHttpLoggingInterceptor() { 
    HttpLoggingInterceptor httpLoggingInterceptor = new HttpLoggingInterceptor(new HttpLoggingInterceptor.Logger() { 
     @Override 
     public void log(String message) { 
      Logger.t(5).i(message); 
     } 
    }); 
    httpLoggingInterceptor.setLevel(HttpLoggingInterceptor.Level.BODY); 
    return httpLoggingInterceptor; 
} 

/** 
* Cache Are available when Network Connection is not available 
* 
* @return Caching Interceptor 
*/ 
@Provides 
@Singleton 
Interceptor getCachingInterceptor(final Application mApp) { 
    return new Interceptor() { 
     @Override 
     public Response intercept(Chain chain) throws IOException { 
      Request request = chain.request(); 
      if (ConnectionUtil.isNetworkAvailable(mApp)) { 
       request = request.newBuilder().header("Cache-Control", "public, max-age=" + 60).build(); 
      } else { 
       request = request.newBuilder().header("Cache-Control", "public, only-if-cached, max-stale=" + 60 * 60 * 24 * 7).build(); 
      } 
      return chain.proceed(request); 
     } 
    }; 
} 


@Provides 
@Singleton 
Scheduler provideScheduler() { 
    return Schedulers.io(); 
} 

}

Here's my request headers

+0

'Call.execute()'の後に応答がありますか? 私が考えることができるのは、あなたの 'cachingInterceptor'が突発的にIOExceptionを投げることだけです。 –

+0

ご回答いただきありがとうございますが、私はIOExceptionを取得しませんでした。私は私の質問を修正しました。もう一度コードをチェックしてください。 – user7434432

+1

これは 'addInterceptor'の代わりに' addNetworkInterceptor'を使ったからです – EpicPandaForce

答えて

1

使用addInterceptoraddNetworkInterceptorありません。

ほとんどの場合、ネットワークインターセプタではなく、アプリケーションインターセプタが必要です。

ネットワークインターセプタは、要求がネットワークにヒットしたときにのみ呼び出され、キャッシュヒットは呼び出されません。

関連する問題