WebClient, актуальный клиент для HTTP-запросов, предлагает три основных подхода к обработке ответов: блокировка потока с помощью
WebClient предоставляет методы
Для преобразования данных, издаваемых
Ошибки в реактивных стримах, включая HTTP-ошибки, завершают последовательность операций и переходят в
.block()
, передача ответа напрямую из потока Netty (возвращение Mono<V>
), или использование .subscribe()
для асинхронной обработки в Netty. Первый способ прост, но обладает недостатками синхронного API. Для асинхронной обработки важно понимать, как строятся и выполняются реактивные цепочки: сборка происходит сверху-вниз, подписка – снизу-вверх, а обработка элементов – сверху-вниз. Изображение носит иллюстративный характер
WebClient предоставляет методы
exchange()
, retrieve()
и exchangeToMono()
для работы с ответами. exchange()
устарел и возвращает Mono<ClientResponse>
, а retrieve()
дает доступ к методам toEntity()
и bodyToMono()
. Наиболее гибкий exchangeToMono()
позволяет кастомизировать обработку ответа через лямбда-функцию, предоставляя доступ к ClientResponse
, и выносить логику обработки в отдельные методы и классы, повышая переиспользуемость кода. Для преобразования данных, издаваемых
Mono
, используются операторы map()
для синхронных преобразований и flatMap()
для асинхронных. flatMap()
необходим при выполнении нескольких запросов последовательно. Методы doOnNext()
, doOnSuccess()
, doOnError()
позволяют добавлять побочные эффекты без изменения издаваемого значения. Ошибки в реактивных стримах, включая HTTP-ошибки, завершают последовательность операций и переходят в
onError
. Их необходимо обрабатывать на уровне приложения. Для этого используются onErrorResume()
для обработки и возвращения альтернативного значения, onErrorMap()
для преобразования исключения и onErrorReturn()
для возвращения значения по умолчанию. Также можно использовать doOnError()
для выполнения действий, не меняя ошибку. При неперехваченных ошибках в неблокирующих вызовах, они попадают в логи, что является нежелательным, поэтому всегда рекомендуется задавать обработчик onError
.