我有一个使用HTTP Connector的Mule ESB项目,我希望使用XPath来分割/路由XML。
HTTP连接器之后的消息有效负载是org.glassfish.grizzly.utils.BufferInputStream。
将此转换为可以使用“拆分器”或“表达式”(使用XPath)等组件分割/路由的类型的最佳方法是什么?
“对象到XML”似乎不起作用,当有效负载是String(即在HTTP之后使用Object to String)时,拆分器不起作用。如果有标准组件可以做到这一点,我宁愿不编写自定义Java转换器吗?
流量
<http:listener-config name="HTTP_Listener_Configuration" host="0.0.0.0" port="8081" doc:name="HTTP Listener Configuration"/>
<file:connector name="File" autoDelete="true" streaming="true" validateConnections="true" doc:name="File"/>
<flow name="collectionsplitterFlow">
<http:listener config-ref="HTTP_Listener_Configuration" path="/CollectionSplitter" doc:name="HTTP"/>
<splitter expression="#[xpath3('//Order')]" doc:name="Splitter"/>
<logger level="INFO" doc:name="Logger"/>
</flow>
要拆分的XML
<?xml version="1.0" encoding="UTF-8"?>
<msglist>
<msg>
<Order>
<Id>1</Id>
<Description>Order 1</Description>
</Order>
</msg>
<msg>
<Order>
<Id>2</Id>
<Description>Order 2</Description>
</Order>
</msg>
</msglist>
由于 大卫
答案 0 :(得分:1)
感谢您的回答stackoverflow question帮助解决了我的问题。
<强>答案:强>
将NODESET选项添加到xpath3 MEL,然后将DOM转换为XML转换器,以将DOM对象转换回XML。
#[xpath3('//Order',payload,'NODESET')]
我还必须将所有拆分组件添加到子流中,特别是对于我的HTTP源(因为我不断收到payloadAsString()错误。
骡流
<http:listener-config name="HTTP_Listener_Configuration" host="0.0.0.0" port="8081" doc:name="HTTP Listener Configuration"/>
<file:connector name="File" autoDelete="true" streaming="true" validateConnections="true" doc:name="File"/>
<file:connector name="PickupFile2" autoDelete="true" streaming="false" validateConnections="true" doc:name="File"/>
<mulexml:object-to-xml-transformer returnClass="java.lang.String" encoding="UTF-8" name="Object_to_XML" doc:name="Object to XML"/>
<mulexml:dom-to-xml-transformer name="DOM_to_XML" doc:name="DOM to XML"/>
<flow name="collectionsplitterFlow2">
<http:listener config-ref="HTTP_Listener_Configuration" path="/CollectionSplitter" doc:name="HTTP"/>
<set-session-variable variableName="Filename" value="HTTP" doc:name="Session Variable"/>
<flow-ref name="collectionsplitterSub_Flow" doc:name="collectionsplitterSub_Flow"/>
<set-payload value="Response2" doc:name="Set Payload"/>
</flow>
<sub-flow name="collectionsplitterSub_Flow">
<splitter expression="#[xpath3('//Order',payload,'NODESET')]" doc:name="Splitter"/>
<mulexml:dom-to-xml-transformer doc:name="DOM to XML"/>
<logger message="#[payload]" level="INFO" doc:name="Logger"/>
<file:outbound-endpoint path="C:\Mule\CollectionSplitter\Backup\01_SplitFile" outputPattern="#[sessionVars.Filename]-split2-#[function:datestamp].xml" connector-ref="File" responseTimeout="10000" transformer-refs="DOM_to_XML" doc:name="File"/>
</sub-flow>
<flow name="collectionsplitterFlow">
<file:inbound-endpoint path="C:\Mule\CollectionSplitter\In" moveToPattern="#[message.inboundProperties['originalFilename']]-backup-#[function:datestamp].xml" moveToDirectory="C:\Mule\CollectionSplitter\Backup" connector-ref="PickupFile2" responseTimeout="10000" doc:name="File">
<file:filename-regex-filter pattern="(.*).xml" caseSensitive="false"/>
</file:inbound-endpoint>
<set-session-variable variableName="Filename" value="#[message.inboundProperties['originalFilename']]" doc:name="Session Variable"/>
<flow-ref name="collectionsplitterSub_Flow" doc:name="collectionsplitterSub_Flow"/>
<logger level="INFO" doc:name="Logger" message="#[payload]"/>
</flow>
答案 1 :(得分:0)
你的流程很好看。我在我的机器上试过它,看到你来自哪里。尝试将#[xpath3('// Order')]中的Mule表达式更改为#[xpath('// Order')]。这样做会导致Mule成功生成两个Mule消息 - 每个Order元素一个消息。
HTH,
贾斯汀