web-dev-qa-db-de.com

Bekam diesen Fehler mit Retrofit2 & OkHttp3. Host "<Hostname>" kann nicht aufgelöst werden: Keine mit Hostname verknüpfte Adresse

Ich benutze das Retrofit 2 und OkHttp3, um Daten vom Server anzufordern. Ich habe gerade einen Offline-Cache-Code hinzugefügt, der jedoch nicht wie erwartet funktioniert. Ich habe den Fehler "Host konnte nicht aufgelöst werden" <> ": Keine Adresse mit Hostname verknüpft." 

Dies tritt auf, wenn versucht wird, die abgerufenen Daten aus dem Cache abzurufen (wenn keine Internetverbindung besteht). Ein Code-Snippet befindet sich unten.

public static Interceptor provideCacheInterceptor() {
    return new Interceptor() {
        @Override
        public Response intercept(Chain chain) throws IOException {
            Response response = chain.proceed(chain.request());

            // re-write response header to force use of cache
            CacheControl cacheControl = new CacheControl.Builder()
                    .maxAge(2, TimeUnit.MINUTES)
                    .build();

            return response.newBuilder()
                    .header(CACHE_CONTROL, cacheControl.toString())
                    .build();
        }
    };
}

public static Interceptor provideOfflineCacheInterceptor() {
    return new Interceptor() {
        @Override
        public Response intercept(Chain chain) throws IOException {
            Request request = chain.request();

            if (!hasNetwork) {
                CacheControl cacheControl = new CacheControl.Builder()
                        .onlyIfCached()
                        .maxStale(7, TimeUnit.DAYS)
                        .build();

                request = request.newBuilder()
                        .removeHeader("Pragma")
                        .cacheControl(cacheControl)
                        .build();
            }

            return chain.proceed(request);
        }
    };
}

private static Cache provideCache() {
    Cache cache = null;
    try {
        cache = new Cache(new File(AdeptAndroid.getInstance().getCacheDir(), "http-cache"),
                10 * 1024 * 1024); // 10 MB
    } catch (Exception e) {
        Log.d("Test", "Could not create Cache!");
    }
    return cache;
}

Und schließlich ist eine Methode, die all dies kombiniert, hier.

private static OkHttpClient provideOkHttpClient() {
    return new OkHttpClient.Builder()
            .addInterceptor(provideHttpLoggingInterceptor())
            .addInterceptor(provideOfflineCacheInterceptor())
            .addNetworkInterceptor(provideCacheInterceptor())
            .cache(provideCache())
            .build();
}
14

Ihre Serverantwort hat einen "Pragma: no-cache" -Header. Sie sollten diesen Header in Ihrem Antwort-Interceptor entfernen, nicht Ihren Request-Interceptor.

In Ihrem aktuellen Code haben Sie ihn aus dem Request Interceptor entfernt.

Ihre provideCacheInterceptor() sollte so aussehen:

public static Interceptor provideCacheInterceptor() {
    return new Interceptor() {
        @Override
        public Response intercept(Chain chain) throws IOException {
            Response response = chain.proceed(chain.request());

            // re-write response header to force use of cache
            CacheControl cacheControl = new CacheControl.Builder()
                   .maxAge(2, TimeUnit.MINUTES)
                   .build();

           return response.newBuilder()
                    .header(CACHE_CONTROL, cacheControl.toString())
                    .removeHeader("Pragma")
                    .build();
        }
    };
}
1
Ibrahim

Bitte überprüfen Sie Ihr Netzwerk "Einschalten" in Manifest-Dateiberechtigung AUS Flugzeugmodus im Emulator

0
O Thạnh Ldt

Ich hatte den gleichen Fehler in meinem Projekt mit Kotlin, und ich habe es so behoben:

client.addInterceptor(provideOfflineCacheInterceptor(context))
client.addNetworkInterceptor(provideCacheInterceptor(context))

private fun provideOfflineCacheInterceptor(context: Context): Interceptor {
        return Interceptor { chain ->
            var request = chain.request()
            var cacheHeaderValue = if (!hasNetwork(context)!!){
                    "public, only-if-cached, max-stale=" + 60 * 60 * 24 * 1
                } else {
                    "public, max-age=" + 5
                }
            request = request.newBuilder().header("Cache-Control", cacheHeaderValue).build()
            chain.proceed(request)
        }
    }

    private fun provideCacheInterceptor(context: Context): Interceptor {
        return Interceptor { chain ->
            val request = chain.request()
            var cacheHeaderValue = if (!hasNetwork(context)!!){
                    "public, only-if-cached, max-stale=" + 60 * 60 * 24 * 1
                } else {
                    "public, max-age=" + 5
                }
            //request = request.newBuilder().build()
            val response = chain.proceed(request)
            response.newBuilder()
                    .removeHeader("Pragma")
                    .removeHeader("Cache-Control")
                    .header("Cache-Control", cacheHeaderValue)
                    .build()
        }
    }
0
Ghizlane Lotfi