Как мне написать сервис Angular 2 с CORS в Ionic?

У меня возникли проблемы с перемещением моей службы JavaScript Angular 1 в службу TypeScript Angular 2 с использованием http для выполнения запроса CORS (это использует Ionic версии 2). В Angular 1 я делаю что-то вроде этого.

angular.module('app.services',[])
.factory('LoginService', ['$http', function($http) { 
 var service = {};

 service.isUserLoggedIn = function() {
  var restUrl = 'http://10.10.10.25:8080/api/user/isloggedin';
  var options = {
   method: 'GET', url: restUrl, withCredentials: true,
   headers: { 
    'x-request-with': 'XMLHttpRequest', 
    'x-access-token': 'sometoken' 
   }
  };
  return $http(options);
 };

 return service;
}])

В Angular 2 с использованием TypeScript многое изменилось (Promises / Observables). Моя попытка пока выглядит следующим образом.

import { Injectable } from '@angular/core';
import { Headers, Http, Response, RequestMethod, RequestOptionsArgs } from '@angular/http';
import { Observable } from 'rxjs/Observable';

@Injectable()
export class LoginService {
  constructor(private _http:Http) {

  }

  isLoggedIn():boolean {
    var r:any;
    var e:any;
    let url = 'http://10.10.10.25:8080/api/user/isloggedin';
    let options:RequestOptionsArgs = {
      url: url,
      method: RequestMethod.Get,
      search: null,
      headers: new Headers({
        'Content-Type': 'application/json',
        'X-Requested-With': 'XMLHttpRequest',
        'x-access-token' : 'sometoken'
      }),
      body: null
    };
    this._http.get(url, options).map(this.extractData).catch(this.handleError)
      .subscribe(
       response => { r = <any>response; console.log(r); }, 
       error => { e = <any>error; console.log(e); });
    return false;
  }

  private extractData(response:Response) {
    let body = response.json();
    return body.data || { };
  }

  private handleError(error:any) {
    let errMsg = (error.message) ? error.message :
      error.status ? `${error.status} - ${error.statusText}` : 'Server error';
    console.log('error = ' + errMsg);
    return Observable.throw(errMsg);
  }
}

Я больше не уверен, как решить в Angular 2 то, что было в Angular 1.

  • withCredentials (обратите внимание, что https://angular.io/docs/js/latest/api/http/index/RequestOptionsArgs-interface.html#!#withCredentials-anchor говорит, что RequestOptionsArgs должно иметь поле withCredentials, но я получаю сообщение об ошибке в IDE Visual Studio Code говорит, что его нет в интерфейсе; ionic, вероятно, использует более старую версию angular 2?)
  • заголовки (x-request-with и x-access-token)
  • фактический ответ

Я немного больше искал и смог понять, как вставлять заголовки и правильно обрабатывать подписку. Однако withCredentials все еще остается проблемой.

Я нашел это сообщение SO angular2 xhrfields withcredentials true и изменил свой конструктор следующим образом. Теперь это работает.

constructor(@Inject(Http) private _http:Http) {
    let _build = (<any> _http)._backend._browserXHR.build;
    (<any> _http)._backend._browserXHR.build = () => {
      let _xhr = _build();
      _xhr.withCredentails = true;
      return _xhr;
    }
  }

person Jane Wayne    schedule 15.06.2016    source источник


Ответы (1)


Поддержка withCredentails будет присутствовать в версии RC2 Angular2, которая скоро будет выпущена. Это не часть версии RC1 ... Вам нужно немного подождать.

С RC2 вы сможете использовать это свойство непосредственно в параметрах запроса:

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

См. Этот вопрос для получения более подробной информации:

person Thierry Templier    schedule 15.06.2016