Observable增加了一倍

时间:2016-02-27 11:40:12

标签: login typescript rxjs

我对Rxjs相当新,但现在我遇到了问题: 我有这段代码:

const requestStream = Observable.of({
    url: siteLocation + 'login',
    body: {
        personnelNumber : personnelNumber,
        password : password
    }
});

requestStream.subscribe(response => {
    console.log("Hello")
});

const responseStream : Observable<Response> = requestStream
.flatMap(request => {
    console.log("Hello2");

    return this.http.post(request.url, JSON.stringify(request.body), {
        headers: this.getHeaders()
    });
});

const jsonStream = responseStream.map(response => response.json());

jsonStream.subscribe(json => {
    console.log("Hello3");
    this.authToken = json.authToken;
});

但是我得到了这个输出:

Hello
Hello2
Hello2
Hello3

为什么flatMap会使我的请求流加倍,即使这是缩进的,为什么生成的json流再次正常?

问题是,我用这个片段登录我的API,然后我登录两次,因此第二次登录时,我的第一个authToken失效了,我得到了一个新的。但是因为我只保存第一个,我保存的令牌永远不会有效。

我检查了Chrome中的请求和响应,它们都是正确的。

1 个答案:

答案 0 :(得分:0)

我发现了这个问题。

问题是我订阅了json流。当我使用map(因为我想重用流)时,一切正常。 我认为这是一个错误,我会报告。