2016-09-19 9 views
0

XMLペイロードをCSVメッセージに変換するのに必要な単純なプロキシサービスがあります。この目的のために私はsmooks mediatorを使用しています。以下は私のプロキシサービスです。WSO2 ESB Smooks - XMLからCSVへの変換

<?xml version="1.0" encoding="UTF-8"?> 
<proxy name="TestProxy" startOnLoad="true" trace="disable" 
    transports="http https" xmlns="http://ws.apache.org/ns/synapse"> 
    <target> 
    <inSequence> 
     <log level="custom"> 
     <property name="STATUS" value="TESTING PROXY SERVICE"/> 
     </log> 
     <payloadFactory media-type="xml"> 
     <format> 
       <csv-set> 
       <csv-record number="2"> 
        <Name>Jhone</Name> 
        <City>Colombo</City> 
        <Age>32</Age> 
       </csv-record> 
       <csv-record number="3"> 
        <Name>Doe</Name> 
        <City>Jaffna</City> 
        <Age>32</Age> 
       </csv-record> 
       </csv-set>    
     </format> 
     <args/> 
     </payloadFactory> 
     <log level="full"/> 
     <smooks config-key="gov:Test/smooks/TestSmooksConfig.xml"> 
     <input type="xml"/> 
     <output type="text"/> 
     </smooks> 
     <log level="custom"> 
     <property name="STATUS" value="PROCESSED MSG******"/> 
     </log> 
     <log level="full"/> 
    </inSequence> 
    <outSequence/> 
    <faultSequence/> 
    </target> 
</proxy> 

以下は私のSmooks構成です。

<?xml version="1.0" encoding="UTF-8"?><smooks-resource-list xmlns="http://www.milyn.org/xsd/smooks-1.1.xsd" xmlns:csv="http://www.milyn.org/xsd/smooks/csv-1.2.xsd" xmlns:ftl="http://www.milyn.org/xsd/smooks/freemarker-1.1.xsd"> 
    <params> 
    <param name="inputType">input.xml</param> 
    <param name="stream.filter.type">SAX</param> 
    <param name="input.xml" type="input.type.actived">File:/F:\Practicals\WSO2\vfs_file_listening\input-csv\b.xml</param> 
    </params> 
    <ftl:freemarker applyOnElement="#document"> 
    <ftl:template><![CDATA["Name","City","Age" 
<#list .vars["csv-set"]["csv-record"] as csv_record> 
"${.vars["csv_record"]["Name"]}","${.vars["csv_record"]["City"]}","${.vars["csv_record"]["Age"]}" 
</#list>]]></ftl:template> 
    <param name="includeFieldNames">true</param> 
    <param name="seperator">,</param> 
    <param name="quote">"</param> 
    <param name="csvFields">Name,City,Age</param> 
    <param name="messageType">CSV</param> 
    <param name="templateDataProvider">input</param> 
    </ftl:freemarker> 
    <resource-config selector="#document"> 
    <resource>org.milyn.delivery.DomModelCreator</resource> 
    </resource-config> 
</smooks-resource-list> 

出力メッセージは次のものだけを出力します。

<?xml version='1.0' encoding='utf-8'?> 
<soapenv:Envelope xmlns:soapenv="http://www.w3.org/2003/05/soap-envelope"> 
    <soapenv:Body> 
     <ax:text xmlns:ax="http://ws.apache.org/commons/ns/payload">"Name","City","Age"</ax:text> 
    </soapenv:Body> 
</soapenv:Envelope> 

入力XMLタグのデータではありませんが、誰かが間違っていることを指摘できますか?

ありがとうございます。

答えて

2

私はこれを次のSmooks構成で実現できました。 (wso2 devのサポート、感謝Evanthikaの助けを借りて)。行われている

<?xml version="1.0" encoding="UTF-8"?> 
<smooks-resource-list xmlns="http://www.milyn.org/xsd/smooks-1.1.xsd" 
    xmlns:ftl="http://www.milyn.org/xsd/smooks/freemarker-1.1.xsd"> 
    <params> 
     <param name="stream.filter.type">SAX</param> 
     <param name="inputType">input.xml</param> 
     <param name="input.xml" type="input.type.actived">File:/C:\Work\2016\09_ESB_Auto_Mail_rpts\TestFiles\TestFileXMLCSVMap.xml 
     </param> 
     <param name="default.serialization.on">true</param> 
    </params> 
    <resource-config selector="csv-set,csv-record"> 
     <resource>org.milyn.delivery.DomModelCreator</resource> 
    </resource-config> 
    <ftl:freemarker applyOnElement="csv-record"> 
     <ftl:template> 
      <!-- <#ftl ns_prefixes={"D":"http://ws.apache.org/ns/synapse"}> ${.vars["csv-record"].Name},${.vars["csv-record"].City},${.vars["csv-record"].Age} --> 
     </ftl:template> 
     <param name="quote">"</param> 
     <param name="includeFieldNames">true</param> 
     <param name="csvFields">Name,City,Age</param> 
     <param name="seperator">,</param> 
     <param name="messageType">CSV</param> 
     <param name="templateDataProvider">input</param> 
    </ftl:freemarker> 
</smooks-resource-list> 

変更され、XML名前空間と

  • <ftl:template>。 (私の場合、それはデータサービスから来ています。したがって、の名前空間は<#ftl ns_prefixes>タグにあります)。作業するSmooksのため 要素を指摘する

  • <resource-config selector="csv-set,csv-record"><ftl:freemarker applyOnElement="csv-record">

これは誰でも参考にしたいと考えています。