使用注释配置路由器

使用@Router要对方法进行注释,该方法可能会返回MessageChannelString类型。 在后一种情况下,终端节点解析通道名称的方式与解析默认输出通道的方式相同。 此外,该方法可能返回单个值或集合。 如果返回集合,则回复消息将发送到多个渠道。 总而言之,以下方法签名都是有效的:spring-doc.cadn.net.cn

@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 中进行了记录:spring-doc.cadn.net.cn

@Router
public List<String> route(@Header("orderStatus") OrderStatus status)
有关基于 XML 的消息的路由 (包括 XPath 支持),请参阅 XML 支持 - 处理 XML 有效负载

有关路由器配置的更多信息,另请参阅 Java DSL 一章中的消息路由器spring-doc.cadn.net.cn