¿Cómo enviar “Cookie” en el encabezado de solicitud para todas las solicitudes en Angular2?

En realidad, nuestro servidor back-end autentica la solicitud usando Cookie en el encabezado de la solicitud. Sé que se rechazará si configuro un encabezado “Cookie”. Entonces, ¿hay alguna manera de enviar una Cookie al back-end?

Supongo que hay una fase en la que le pides al servidor que te autentique. Después de esto (y si la autenticación es exitosa), el servidor devolverá una cookie en la respuesta. El navegador almacenará esta cookie y la enviará nuevamente para cada llamada.

Dicho esto, en el caso de las solicitudes de dominio cruzado (CORS), debe establecer el valor withCredentials of XHR en true para que el navegador agregue cookies en sus solicitudes.

Para habilitar esto con Angular2, necesitamos extender la clase BrowserXhr como se describe a continuación:

 @Injectable() export class CustomBrowserXhr extends BrowserXhr { constructor() {} build(): any { let xhr = super.build(); xhr.withCredentials = true; return (xhr); } } 

y anula el proveedor BrowserXhr con el extendido:

 bootstrap(AppComponent, [ HTTP_PROVIDERS, provide(BrowserXhr, { useClass: CustomBrowserXhr }) ]); 

Vea estas preguntas para más detalles:

  • Set-cookie en respuesta no establecida para la solicitud de publicación de Angular2
  • xmlhttprequest y set-cookie y cookie

Editar (siguiendo el comentario del freaker )

Desde RC2, puede usar la propiedad withCredentials directamente dentro de la configuración de solicitud como se describe a continuación:

 this.http.get('http://...', { withCredentials: true }) 

Editar (siguiendo el comentario [maxou])

Recuerde incluir withCredentials: true en cada solicitud .

En Angular5 puedes escribir un Interceptor Http:

auth.interceptor.ts

 import { Observable } from 'rxjs/Observable'; import { HttpInterceptor, HttpRequest, HttpHandler, HttpEvent } from '@angular/common/http'; import { Injectable } from '@angular/core'; @Injectable() export class AuthInterceptor implements HttpInterceptor { constructor() {} intercept(request: HttpRequest, next: HttpHandler): Observable> { request = request.clone({ withCredentials: true }); return next.handle(request); } } 

Y agregar a los proveedores una matriz de app.module

app.module.ts

 import { AuthInterceptor } from './services/auth.interceptor'; import { HTTP_INTERCEPTORS } from '@angular/common/http'; import { HttpClientModule } from '@angular/common/http'; imports: [ BrowserModule,HttpClientModule,FormsModule ], providers: [ { provide: HTTP_INTERCEPTORS, useClass: AuthInterceptor, multi: true, } ]