拆分 XML 消息

XPathMessageSplitter 支持消息负载为 StringDocument 类型。分割器使用提供的 XPath 表达式将负载分割成多个节点。默认情况下,这将导致每个 Node 实例成为新消息的负载。当每个消息都应为 Document 时,您可以设置 createDocuments 标志。当传入 String 负载时,负载将被转换,然后分割,然后再转换回多个 String 消息。XPath 分割器实现了 MessageHandler,因此应与合适的端点结合配置(有关更简单的配置替代方案,请参阅以下示例后的命名空间支持示例)。以下示例配置了一个使用 XPathMessageSplitter 的 Bean。

<bean id="splittingEndpoint"
      class="org.springframework.integration.endpoint.EventDrivenConsumer">
    <constructor-arg ref="orderChannel" />
    <constructor-arg>
        <bean class="org.springframework.integration.xml.splitter.XPathMessageSplitter">
            <constructor-arg value="/order/items" />
            <property name="documentBuilder" ref="customisedDocumentBuilder" />
            <property name="outputChannel" ref="orderItemsChannel" />
        </bean>
    </constructor-arg>
</bean>

XPath 分割器命名空间支持允许您创建一个具有输入通道和输出通道的消息端点,如下例所示。

<!-- Split the order into items and create a new message for each item node -->
<int-xml:xpath-splitter id="orderItemSplitter"
                       input-channel="orderChannel"
                       output-channel="orderItemsChannel">
    <int-xml:xpath-expression expression="/order/items"/>
</int-xml:xpath-splitter>

<!-- Split the order into items, create a new document for each item-->
<int-xml:xpath-splitter id="orderItemDocumentSplitter"
                       input-channel="orderChannel"
                       output-channel="orderItemsChannel"
                       create-documents="true">
    <int-xml:xpath-expression expression="/order/items"/>
    <int:poller fixed-rate="2000"/>
</int-xml:xpath-splitter>

从 4.2 版本开始,XPathMessageSplitter 在请求 payload 不是 org.w3c.dom.Node 类型时,为 javax.xml.transform.Transformer 实例公开了 outputProperties(例如 OutputKeys.OMIT_XML_DECLARATION)属性。以下示例定义了一个属性,并将其与 output-properties 属性一起使用。

<util:properties id="outputProperties">
	<beans:prop key="#{T (javax.xml.transform.OutputKeys).OMIT_XML_DECLARATION}">yes</beans:prop>
</util:properties>

<xpath-splitter input-channel="input"
             output-properties="outputProperties">
    <xpath-expression expression="/orders/order"/>
</xpath-splitter>

4.2 版本 开始,XPathMessageSplitter 公开了 iterator 选项作为 boolean 标志(默认为 true)。这允许在下游流中“流式传输”分割的节点。当 iterator 模式设置为 true 时,每个节点在迭代时都会被转换。当为 false 时,所有条目首先被转换,然后开始将分割的节点发送到输出通道。(您可以将差异视为“转换、发送、转换、发送”与“转换、转换、发送、发送”。)有关更多信息,请参阅 Splitter