0

在发布此之前,我去了许多其他类似的问题,但无法找到解决方案。像 Angular 2 - 在每个 Http 请求之前注入授权令牌

我正在使用 AWS 会话,它为我提供了发出 HTTP 请求的授权令牌。现在获取会话可以是异步操作,具体取决于刷新令牌的需要。

问题: 我无法链接获取会话然后进行 HTTP 调用。

版本Angular 5、RxJs 5.5.2

AuthService 的获取会话功能。

    getSession(): Observable<any> {
        const sessionOb = new Subject<CognitoUserSession>();
        // AysnFn4session is a callback implementation
        AysnFn4session((err, session) => { 
                console.log('Found Session');
                sessionOb.next(session);
                sessionOb.complete();
            });
        return sessionOb;
    }

API 服务的 get 函数 - Trail 1

get(url: string, options?: RequestOptionsArgs): Observable<Response> {
    return this._authService.getSession().switchMap((session) => {
      console.log('dasdasd');
      let token = '';
      if (session) {
        token = session.getIdToken().getJwtToken();
        options = options || {};
        options.headers = options.headers || new Headers();
        options.headers.append('Authorization', token);
      }
      return this._http.get(url, options);
    });
  }

API 服务的 get 函数 - Trail 2

get(url: string, options?: RequestOptionsArgs): Observable<Response> {
return this._authService.getSession().pipe(mergeMap((session) => {
  console.log('So what??');
  let token = '';
  if (session) {
    token = session.getIdToken().getJwtToken();
    options = options || {};
    options.headers = options.headers || new Headers();
    options.headers.append('Authorization', token);
  }
  return this._http.get(url, options);
}));
}

这里我如何调用这个 api。

getItemInfo(item) {
return this._apiHttp.get('/assets/data/item.json')
  .map(res => {
    console.log(res);
    return res.json();
  })
  .subscribe(data => console.log(data),
     err => console.log(err), 
     () => console.log('done'));
}

现在的问题是在这两种情况下控制台都只是打印。而不是进行 http 调用。

Found Session
done

我不明白我在使用 switchmap 的 mergemap 以完成 http 请求时出错的地方。

4

1 回答 1

1

错误在于getSession()。您的 AsynFn4session 回调在主题的观察者正在收听之前完成。(主体的观察者仅接收在其订阅后发出的值)。这意味着观察者永远不会收到主题发射,因此可观察序列不会继续。我会使用可观察对象而不是主题

getSession(): Observable<any> {
    return new Observable(observer => {
        AsynFn4session((err, session) => {
            observer.next(session);
            observer.complete();
        });
    });
}
于 2017-12-18T17:34:47.000 回答