Http Interceptor¶
Angular HTTP Interceptor позволяет перехватывать HTTP-запросы перед их отправкой и вносить в них необходимые изменения. То же самое справедливо и для ответов сервера.
Наиболее частое их применение — отправка авторизационных данных, логирование и обработка серверных ошибок.
Начнем сразу с примера и детально его рассмотрим.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |
|
Создание сервиса начинается с внедрения интерфейса Angular HttpIntrceptor
из @angular/common/http
и реализации его метода intercept()
.
intercept()
модифицирует исходный запрос и возвращает объект Observable
события HttpEvent<any>
, который в свою очередь возвращает метод next()
объекта типа HttpRequest
.
В качестве аргумента next()
принимает модифицированный объект запроса.
Для манипуляций с объектом запроса используется метод clone()
, вызываемый у экземпляра класса HttpRequest
. Он позволяет изменять свойства объекта, пока создает его копию, и возвращает его модифицированный экземпляр.
Ответы сервера также попадают в метод intercept()
. Чтобы "перехватить" их, нужно определить тип события (any
в HttpEvent<any>
).
Сделать это можно используя оператор tap()
, который принимает в качестве аргумента возвращаемое значение Observable
. Все успешные ответы сервера принадлежат к классу HttpResponse
, ошибки — к классу HttpErrorResponse
.
В зависимости от ответа сервера объект события содержит соответствующие событию данные.
В приложение Angular HTTP Interceptor внедряется аналогично сервису.
1 2 3 4 5 6 7 8 9 |
|
Сперва необходимо импортировать injection-токен HTTP_INTERCEPTORS
, затем в массиве providers
записать объект, подобный тому, что записан в примере выше.
Обязательный параметр {multi: true}
говорит, что injection-токен HTTP_INTERCEPTORS
внедряет не одно, а массив значений. Такой механизм позволяет создавать в приложении Angular неограниченное количество HTTP Interceptor-ов.