2016-11-14 17 views
0

次のフォーマットのオーダーデータはペイロードにあります。Muleペイロードが正しいデータを表示していません

{ 
    "orders" : { 
     "order" : [ { 
      "id" : "4358294728", 
      "fulfillment" : { 
       "tracking_number" : "917", 
       "line-items" : { 
        "id" : "8367649608" 
       } 
      } 
     }, { 
      "id" : "4358301768", 
      "fulfillment" : { 
       "tracking_number" : "918", 
       "line-items" : [ { 
        "id" : "8367663240" 
       }, { 
        "id" : "8367663304" 
       }, { 
        "id" : "8367663368" 
       } ] 
      } 
     } ] 
    } 
} 

私は総数を取得したいと思います。このペイロードからの注文。 私は#[message.payload.orders.order.size()]を使用しています。 正しい出力を出しています。

しかし、あなたは所望の出力を得るために私を助けてくださいすることができ、それは間違っている= 2の出力を与えている。しかし、それは1

{ 
    "orders" : { 
     "order" : { 
      "id" : "4358153416", 
      "fulfillment" : { 
       "tracking_number" : "915", 
       "line-items" : { 
        "id" : "8367362760" 
       } 
      } 
     } 
    } 
} 

になります単一の注文のために?

答えて

0

私は、次の設定で正しい番号を取得しています: -

<http:listener-config name="HTTP_Listener_Configuration" host="0.0.0.0" port="8081" doc:name="HTTP Listener Configuration"/> 
    <flow name="Flow1" > 
    <http:listener config-ref="HTTP_Listener_Configuration" path="/test" doc:name="HTTP"/> 
    <json:json-to-object-transformer doc:name="JSON to Object" returnClass="java.util.HashMap"/> 
    <logger message="Order size #[message.payload.orders.order.size()] " level="INFO" doc:name="Logger"/> 
    <json:object-to-json-transformer doc:name="Object to JSON"/> 
    </flow> 

とはい、あなたのJSONが間違っ..ですこれは以下のようになります - あなたは後[を逃した

{ 
    "orders" : { 
     "order" :[ { 
      "id" : "4358153416", 
      "fulfillment" : { 
       "tracking_number" : "915", 
       "line-items" : { 
        "id" : "8367362760" 
       } 
      } 
     }] 
    } 
} 

注文

1

私はあなたのjsonの構造に問題があると思います。第一 :

{ 
    "orders" : { 
     "order" : { 
      "id" : "4358153416", 
      "fulfillment" : { 
       "tracking_number" : "915", 
       "line-items" : { 
        "id" : "8367362760" 
       } 
      } 
     } 
    } 
} 

項目orderが配列ではないので、それ内部の二つの要素持っているので、それは結果として「2」を与える:idfullfillmentを。あなたはこの問題を解決することができます

、あなたのJSONが適切に生成されたことによって、それが(「[]」ドを確認してください)。このようになります:

{ 
    "orders" : { 
     "order" : [{ 
      "id" : "4358153416", 
      "fulfillment" : { 
       "tracking_number" : "915", 
       "line-items" : { 
        "id" : "8367362760" 
       } 
      } 
     }] 
    } 
} 

また、アイテムorderは、明示的である必要はありません。 ordersの配列が必要です。元のjsonは次のとおりです。

{ 
    "orders" : [ 
     { 
      "id" : "4358294728", 
      "fulfillment" : { 
       "tracking_number" : "917", 
       "line-items" : { 
        "id" : "8367649608" 
       } 
      } 
     }, 
     { 
      "id" : "4358301768", 
      "fulfillment" : { 
       "tracking_number" : "918", 
       "line-items" : [ { 
        "id" : "8367663240" 
       }, { 
        "id" : "8367663304" 
       }, { 
        "id" : "8367663368" 
       } ] 
      } 
     } 
     ] 
} 
関連する問題