对于最新的稳定版本,请使用 Spring Integration 6.4.0! |
使用 XPath 路由 XML 消息
与基于 SPEL 的路由器类似, Spring 集成提供了对基于 XPath 表达式的路由消息的支持,这允许你创建具有 input 通道但没有输出通道的消息端点。 相反,一个或多个 output channel 是动态确定的。 以下示例说明如何创建此类路由器:
<int-xml:xpath-router id="orderTypeRouter" input-channel="orderChannel">
<int-xml:xpath-expression expression="/order/type"/>
</int-xml:xpath-router>
有关 Router 之间通用属性的概述,请参阅 Common Router Parameters。 |
在内部,XPath 表达式作为 type 计算并转换为表示通道名称的 a。
通常,此类列表包含单个通道名称。
但是,根据 XPath 表达式的结果,如果 XPath 表达式返回多个值,则 XPath 路由器也可以具有收件人列表路由器的特征。
在这种情况下,将包含多个频道名称。
因此,消息将发送到列表中的所有通道。NODESET
List<String>
List<String>
因此,假设传递给以下 router 配置的 XML 文件包含许多表示通道名称的子元素,则消息将发送到所有这些通道:responder
<!-- route the order to all responders-->
<int-xml:xpath-router id="responderRouter" input-channel="orderChannel">
<int-xml:xpath-expression expression="/request/responders"/>
</int-xml:xpath-router>
如果返回的值不直接表示通道名称,则可以指定其他映射参数以将这些返回的值映射到实际的通道名称。
例如,如果表达式产生两个值 ( 和 ),但您不想将响应方名称与通道名称耦合,则可以提供其他映射配置,例如:/request/responders
responderA
responderB
<!-- route the order to all responders-->
<int-xml:xpath-router id="responderRouter" input-channel="orderChannel">
<int-xml:xpath-expression expression="/request/responders"/>
<int-xml:mapping value="responderA" channel="channelA"/>
<int-xml:mapping value="responderB" channel="channelB"/>
</int-xml:xpath-router>
如前所述,XPath 表达式的默认计算类型是 ,它被转换为通道名称的 a,它处理单通道场景以及多通道场景。NODESET
List<String>
尽管如此,某些 XPath 表达式可能从一开始就计算为 type。
例如,请考虑以下 XPath 表达式:String
name(./node())
此表达式返回根节点的名称。
如果使用的是默认评估类型,则会导致异常。NODESET
对于这些方案,您可以使用 attribute ,它允许您管理评估类型。
这是默认的。
但是,如果将其设置为 ,则使用评估类型。evaluate-as-string
FALSE
TRUE
String
XPath 1.0 指定了 4 种数据类型:
当 XPath Router 使用 optional 属性计算表达式时,返回值由 XPath 规范中定义的函数确定。
这意味着,如果表达式选择多个节点,它将返回第一个节点的字符串值。 有关详细信息,请参阅: |
例如,如果我们想根据根节点的名称进行路由,我们可以使用以下配置:
<int-xml:xpath-router id="xpathRouterAsString"
input-channel="xpathStringChannel"
evaluate-as-string="true">
<int-xml:xpath-expression expression="name(./node())"/>
</int-xml:xpath-router>
XML 负载转换器
对于 XPath 路由器,您还可以指定在 XPath 评估之前转换负载时要使用的 Converter。
因此,XPath Router 支持策略的自定义实现,并且在 XML 中配置元素时,可以通过属性提供对此类实现的引用。XmlPayloadConverter
xpath-router
converter
如果未明确提供此引用,则使用 the。
在大多数情况下,它应该足够了,因为它可以从 Node、Document、Source、File 和 String 类型的有效负载进行转换。
如果你需要扩展该默认实现的能力,那么在大多数情况下,上游 Transformer 通常是更好的选择,而不是在此处提供对此策略的自定义实现的引用。DefaultXmlPayloadConverter