将上下文从一种流量/单声道传递到另一种

时间:2018-07-05 07:01:48

标签: java spring-webflux project-reactor

有趣的事情发生在webflux包中。但是,我在源代码中的旅程并没有解决以下问题。

假设我有以下单声道(或通量):

Mono hello = Mono.empty()
            .subscriberContext(ctx -> ctx.put("message", "hello"));

我在Web过滤器中使用类似的构造,以用承租人和用户数据丰富管道。然后在控制器中使用这样的构造:

Mono world = Mono.subscriberContext()
            .map(ctx -> (String)ctx.get("message"));

您好单声道的上下文填充在世界单声道中。我试图弄清楚这是如何完成的,也用于单元测试。

最后,它仍然是一个谜。我尝试使用在mono / flux对象上都可用的常规方法来执行此操作,但是我没有成功将hello上下文提供给世界mono。您如何融合通量和单声道并将上下文传递给上游运算符?

2 个答案:

答案 0 :(得分:2)

WebFlux使用您的world Mono,并在其之上构建一个反应链,并以Reactor-netty中的HTTP请求作为最终来源。 WebFilter是链结构的一部分,因此它们可以丰富整个链的Context

IIRC Mono.subscriberContext()将在flatMap中使用,这使得主序列Context对其内部可用,因此可以看到{{1}的Context }。

答案 1 :(得分:1)

您想做几件事:

1。)发布订阅者上下文

mono.subscriberContext({ Context context ->
    context.put("key", "value")
})

2。)订阅/访问订阅者上下文

mono.flatMap({ def r ->
    return Mono.subscriberContext().map({ Context context ->
        context.get("key")
        context.get("keyOrMapOrStateObject").put("someKey", "someData")
        return r
    })
})

3。)可能将数据从一个事件传递到下游事件

mono.flatMap({ def r ->
    return Mono.subscriberContext().map({ Context context ->
        def someData = context.get("keyOrMapOrStateObject").get("someKey")
        return r
    })
})

总的来说,它看起来像:(这是古怪的语法)

mono.flatMap({ def r ->
    return Mono.subscriberContext().map({ Context context ->
        context.get("key")
        context.get("keyOrMapOrStateObject").put("someKey", "someData")
        return r
    })
}).flatMap({ def r ->
    return Mono.subscriberContext().map({ Context context ->
        def someData = context.get("keyOrMapOrStateObject").get("someKey")
        return r
    })
}).subscriberContext({ Context context ->
    context.put("key", "value")
    context.put("keyOrMapOrStateObject", new HashMap())
})

这是一个粗略的轮廓-尚未“按原样”准备就绪,但可以帮助您理解模式。

祝你好运!