Ошибка java .lang.illegalstateexception request == null - PullRequest
0 голосов
/ 30 апреля 2020

Может кто-нибудь сказать мне, в чем может быть ошибка? Некоторое время все работало нормально. И теперь оно появляется, а затем исчезает. Ошибка появляется, когда я начинаю вводить адрес в автозаполнении, буду очень признателен !!

При запуске на устройстве появляется следующая ошибка

java.lang.IllegalStateException: request == null
 at okhttp3.Response$Builder.build(Response.java:442)
 at com.sheepapps.domras.data.autocomplete.AutocompleteService$client$1.intercept(AutocompleteService.kt:19)
 at okhttp3.internal.http.RealInterceptorChain.proceed(RealInterceptorChain.java:147)
 at okhttp3.internal.http.RealInterceptorChain.proceed(RealInterceptorChain.java:121)
 at okhttp3.RealCall.getResponseWithInterceptorChain(RealCall.java:250)
 at okhttp3.RealCall$AsyncCall.execute(RealCall.java:201)
 at okhttp3.internal.NamedRunnable.run(NamedRunnable.java:32)
 at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167)
 at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641)
 at java.lang.Thread.run(Thread.java:764)

Ниже кода приложения сама

package com.sheepapps.domras.data.autocomplete

import androidx.core.text.isDigitsOnly
import com.jakewharton.retrofit2.adapter.kotlin.coroutines.CoroutineCallAdapterFactory
import okhttp3.OkHttpClient
import okhttp3.Response
import retrofit2.Retrofit
import retrofit2.converter.gson.GsonConverterFactory
import kotlin.math.pow

class AutocompleteService {

    private val client = OkHttpClient.Builder()
        .addInterceptor {
            try {
                it.proceed(it.request())
            } catch (e: Exception) {
                e.printStackTrace()
                Response.Builder().code(500).build()
            }
        }.build()

    private val service = Retrofit.Builder()
        .baseUrl("https://nominatim.openstreetmap.org/")
        .addConverterFactory(GsonConverterFactory.create())
        .addCallAdapterFactory(CoroutineCallAdapterFactory.invoke())
        .client(client)
        .build()
        .create(AutocompleteAPI::class.java)

    suspend fun search(query: String, lon: Double, lat: Double) =
        service.search(query, "json", "1", "1", 50, "by")
            .apply {
                if (query.split(" ").any { it.isDigitsOnly() }) {
                    sortBy { it.address?.houseNumber ?: "0" }
                } else {
                    sortBy {
                        (it.lon?.toDouble() ?: 0.0 - lon).pow(2) + (it.lat?.toDouble() ?: 0.0
                        - lat).pow(2)
                    }
                }
            }
            .filter { it.address?.road != null }
            .map { it.convert() }
}

Ответы [ 2 ]

1 голос
/ 04 мая 2020

При создании ответа (Response.Builder()) вы должны предоставить запрос.

try {
  it.proceed(it.request())
} catch (e: Exception) {
 e.printStackTrace()
 Response.Builder().request(it.request()).code(500).build()
}
0 голосов
/ 04 мая 2020

Вот полное описание ошибки

java.lang.IllegalStateException: interceptor com.sheepapps.domras.data.autocomplete.AutocompleteService$client$1@744b1f4 returned a response with no body
 at okhttp3.internal.http.RealInterceptorChain.proceed(RealInterceptorChain.java:161)
 at okhttp3.internal.http.RealInterceptorChain.proceed(RealInterceptorChain.java:121)
 at okhttp3.RealCall.getResponseWithInterceptorChain(RealCall.java:250)
 at okhttp3.RealCall$AsyncCall.execute(RealCall.java:201)
 at okhttp3.internal.NamedRunnable.run(NamedRunnable.java:32)
 at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167)
 at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641)
 at java.lang.Thread.run(Thread.java:764)
...