Configuring a Router with Annotations

当使用 @Router 为方法添加注释时,该方法可以返回 MessageChannelString 类型。在后一种情况下,端点解析信道名称,其方式与它解析默认输出信道的方式相同。此外,该方法可以返回单个值或集合。如果返回集合,则应答消息将被发送到多个信道。总而言之,以下方法签名都 valid:

@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 注释的参数,该参数映射到标头值,如下例所示,并在 Annotation Support 中进行了说明:

@Router
public List<String> route(@Header("orderStatus") OrderStatus status)

对于 XML 消息的路由(包括 XPath 支持),请参阅 XML Support - Dealing with XML Payloads

有关路由器配置的更多信息,请参阅 Java DSL 章节中的 Message Routers