WSO2 ESB / WSO2 EI JSON Запрос серверной службы - PullRequest
0 голосов
/ 10 мая 2019

Я отправил JSON-сообщение на внутренний сервер, используя WSO2 EI. Но это отправка неверного формата JSON. Я использовал wso2ei-6.4.0 для этой задачи. Я добавил образец XML-запроса, который я использовал.

<jsonObject>
   <checkInDate>2019-03-25</checkInDate>
   <checkOutDate>2019-03-26</checkOutDate>
   <cityCode>3086</cityCode>
   <hotelCode />
   <roomOccupancyList>
      <jsonArray>
         <?xml-multiple jsonElement?>
         <jsonElement>
            <childAges>0</childAges>
            <numberOfAdults>1</numberOfAdults>
            <numberOfChildren>0</numberOfChildren>
            <roomNo>1</roomNo>
         </jsonElement>         
      </jsonArray>
   </roomOccupancyList>
</jsonObject>

Но я получил следующий запрос JSON со стороны ESB. Один раз отправьте сообщение через службу ESB.

{
    "checkInDate": "2019-06-04", 
    "checkOutDate": "2019-06-05", 
    "cityCode": "1344", 
    "hotelCode": "", 
    "roomOccupancyList": {
        "childAges": "0", 
        "numberOfAdults": "1", 
        "numberOfChildren": "0", 
        "roomNo": "1"
    }
}

Этот " roomOccupancyList " должен иметь объект JSONArray, по умолчанию он отображается как JSONObject. Если я добавил несколько jsonElement здесь, он отображается как JSONArray. Но мне нужен даже один элемент jsonElement. Можете ли вы помочь мне решить эту проблему. Я сослался на следующую ссылку для вышеуказанного задания. wso2 doc link

JSON Response должен загрузить следующий формат.

{
    "checkInDate": "2019-06-04", 
    "checkOutDate": "2019-06-05", 
    "cityCode": "1344", 
    "hotelCode": "", 
    "roomOccupancyList": [
        {
            "childAges": "0", 
            "numberOfAdults": "1", 
            "numberOfChildren": "0", 
            "roomNo": "1"
        }
    ]
}

1 Ответ

0 голосов
/ 13 мая 2019

Я использовал следующий xslt для этого, и он работает без каких-либо проблем.Также вам нужно добавить следующее свойство в папку synapse.properties / ESB_HOME / conf.

synapse.json.to.xml.processing.instruction.enabled=true

Это образец XSLT для дальнейшего использования.

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="2.0"
    xmlns:msxsl="urn:schemas-microsoft-com:xslt"
    xmlns:xsd="http://www.w3.org/2001/XMLSchema"
    xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
    <xsl:output method="xml" />
    <xsl:strip-space elements="*"/>
       <xsl:output indent="yes"/>    

    <xsl:template match="/request">
        <availabilityRequest>       
            <jsonObject>           
               <checkInDate>2019-03-25</checkInDate>
               <checkOutDate>2019-03-26</checkOutDate>
               <cityCode>3086</cityCode>    
               <xsl:variable name="roomCount" select="count(roomsInformation)" />

               <xsl:for-each select="roomsInformation">     
                   <xsl:if test="$roomCount = 1">
                        <xsl:processing-instruction name="xml-multiple"/>
                   </xsl:if>
                   <xsl:variable name="roomIndex" select="position()" /> 
                   <roomOccupancyList>
                        <jsonArray>
                            <childAges>0</childAges>
                                <numberOfAdults>1</numberOfAdults>
                                <numberOfChildren>1</numberOfChildren>
                                <roomNo><xsl:value-of select="$roomIndex" /></roomNo>                                                                              
                        </jsonArray>                                                          
                   </roomOccupancyList> 
                   <xsl:if test="$roomCount = 1">
                        <xsl:copy-of select="Objects"></xsl:copy-of>
                   </xsl:if>                   
               </xsl:for-each>                         
            </jsonObject>   
        </availabilityRequest>          
    </xsl:template>
</xsl:stylesheet>
...