有趣的事情发生在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。您如何融合通量和单声道并将上下文传递给上游运算符?
答案 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())
})
这是一个粗略的轮廓-尚未“按原样”准备就绪,但可以帮助您理解模式。
祝你好运!