2016-09-19 5 views
0

У меня простая прокси-служба, которая необходима для преобразования полезной нагрузки XML в сообщение CSV. Для этого я использую посредник smooks. Ниже приведено мое прокси-сервис.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> 

Изменения, которые были сделаны являются,

  • <ftl:template> с XML-пространства. (В моем случае это происходит из службы данных, следовательно, пространство имен http://ws.apache.org/ns/synapse в теге <#ftl ns_prefixes>).

  • <resource-config selector="csv-set,csv-record"> и <ftl:freemarker applyOnElement="csv-record"> указать на элементы для smooks работать.

Надеюсь, что это поможет в качестве ссылки на всех.

Смежные вопросы