Модернизация / OkHttp3 400 Тело ошибки пусто ⇐ Android
-
Гость
Модернизация / OkHttp3 400 Тело ошибки пусто
Я использую Retrofit 2 в своем проекте Android. Когда я обращаюсь к конечной точке API с помощью метода GET и он возвращает ошибку уровня 400, я вижу содержимое ошибки, когда использую HttpLoggingInterceptor, но когда я получаю обратный вызов Retrofit OnResponse, строка тела ошибки пуста.
Я вижу, что у ошибки есть тело, но я не могу извлечь это тело в контексте обратного вызова Retrofit. Есть ли способ обеспечить доступ к телу?
Спасибо, Адам
Изменить: Ответ, который я вижу от сервера: {"error":{"errorMessage":"Для входной строки: \"000001280_713870281\"","httpStatus":400}
Я пытаюсь получить этот ответ из ответа с помощью: BaseResponse baseResponse = GsonHelper.getObject(BaseResponse.class, response.errorBody().string()); if (baseResponse != null && !TextUtils.isEmpty(baseResponse.getErrorMessage())) ошибка = baseResponse.getErrorMessage();
(GsonHelper — это просто помощник, который передает строку JSON через GSON для извлечения объекта типа BaseResponse)
Вызов response.errorBody().string() приводит к исключению IOException: Content-Length и длина потока не совпадают, но я вижу содержимое буквально двумя строками выше в Log Cat
Я использую Retrofit 2 в своем проекте Android. Когда я обращаюсь к конечной точке API с помощью метода GET и он возвращает ошибку уровня 400, я вижу содержимое ошибки, когда использую HttpLoggingInterceptor, но когда я получаю обратный вызов Retrofit OnResponse, строка тела ошибки пуста.
Я вижу, что у ошибки есть тело, но я не могу извлечь это тело в контексте обратного вызова Retrofit. Есть ли способ обеспечить доступ к телу?
Спасибо, Адам
Изменить: Ответ, который я вижу от сервера: {"error":{"errorMessage":"Для входной строки: \"000001280_713870281\"","httpStatus":400}
Я пытаюсь получить этот ответ из ответа с помощью: BaseResponse baseResponse = GsonHelper.getObject(BaseResponse.class, response.errorBody().string()); if (baseResponse != null && !TextUtils.isEmpty(baseResponse.getErrorMessage())) ошибка = baseResponse.getErrorMessage();
(GsonHelper — это просто помощник, который передает строку JSON через GSON для извлечения объекта типа BaseResponse)
Вызов response.errorBody().string() приводит к исключению IOException: Content-Length и длина потока не совпадают, но я вижу содержимое буквально двумя строками выше в Log Cat
Мобильная версия