此版本仍在开发中,尚未被视为稳定版本。对于最新的稳定版本,请使用 Spring Integration 6.4.3! |
使用注释配置路由器
使用@Router
要对方法进行注释,该方法可能会返回MessageChannel
或String
类型。
在后一种情况下,终端节点解析通道名称的方式与解析默认输出通道的方式相同。
此外,该方法可能返回单个值或集合。
如果返回集合,则回复消息将发送到多个渠道。
总而言之,以下方法签名都是有效的:
@Router
public MessageChannel route(Message message) {...}
@Router
public List<MessageChannel> route(Message message) {...}
@Router
public String route(Foo payload) {...}
@Router
public List<String> route(Foo payload) {...}
除了基于有效负载的路由之外,还可以根据消息标头中作为属性或属性提供的元数据来路由消息。
在本例中,使用@Router
可以包括一个用@Header
,该值映射到 Headers 值,如下例所示,并在 Annotation Support 中进行了记录:
@Router
public List<String> route(@Header("orderStatus") OrderStatus status)
有关基于 XML 的消息的路由 (包括 XPath 支持),请参阅 XML 支持 - 处理 XML 有效负载。 |
有关路由器配置的更多信息,另请参阅 Java DSL 一章中的消息路由器。