骡子从有效载荷中获取值

时间:2015-01-16 03:04:57

标签: mule

<flow name="datamappingFlow1" doc:name="datamappingFlow1">
    <http:inbound-endpoint exchange-pattern="request-response" host="${hostname}" port="${port}" path="account" connector-ref="ConnectorWithoutMuleSession" doc:name="HTTP"/>
    <jersey:resources doc:name="REST">
        <component class="com.mycompany.qb.rest.AccountMappingService"/>
    </jersey:resources>
    <object-to-byte-array-transformer doc:name="Object to Byte Array"/>       
    <byte-array-to-object-transformer doc:name="Byte Array to Object"/>
    <scatter-gather doc:name="upsert to db">
        <flow-ref name="test1" doc:name="Flow Reference"></flow-ref>
        <flow-ref name="test2" doc:name="Flow Reference"></flow-ref>            
    </scatter-gather>
</flow>
<flow name="test1" doc:name="test1">
    <logger message="====Input deduction data is 1======#[payload]" level="INFO" doc:name="Logger"/>
    <logger message="==== Input test1 data    ======#[message.inboundProperties['City']]" level="INFO" doc:name="Logger"/>
    <db:insert config-ref="Oracle_Configuration" doc:name="Database">
        <db:parameterized-query><![CDATA[insert into test1(City)values(#[payload.City])]]></db:parameterized-query>
    </db:insert>
</flow>
<flow name="test2" doc:name="test2">
    <logger message="====Input deduction data is 2======#[payload]" level="INFO" doc:name="Logger"/>
    <logger message="==== Input test2 data    ======#[payload.City]" level="INFO" doc:name="Logger"/>
    <db:insert config-ref="Oracle_Configuration" doc:name="Database">
        <db:parameterized-query><![CDATA[insert into test2(City)values(#[payload.City])]]></db:parameterized-query>
    </db:insert>
</flow>

休息组件:

@Path("/")
public class AccountMappingService {  
        @POST
        @Path("/mapping")
        @Produces(MediaType.APPLICATION_JSON)
        @Consumes(MediaType.APPLICATION_JSON)
        public String dataMapping(@Payload String content){
            log.info("Rest Content is==>\n"+content);
            return content;
        }

输入数据:

    {
    "City":"SFO1"
    }

输出:

====Input deduction data is 2======{
"City":"SFO1"
}
    ==== Input test1 data    ======null

====Input deduction data is 1======{
"City":"SFO1"
}
    ==== Input test2 data    ======null

为什么我在这里得到空值?

2 个答案:

答案 0 :(得分:3)

  

====输入test1数据====== null

来自:

<logger message="==== Input test1 data    ======#[message.inboundProperties['City']]" level="INFO" doc:name="Logger"/>

入站属性由入站端点设置。在您的情况下,您正在使用HTTP入站端点。根据{{​​3}}:

  

为了与以前版本的Mule保持向后兼容,标题和查询参数也会明确地存储在入站属性中。

因此,除非您在发送给您的流的HTTP请求中传递名为City的HTTP标头或查询参数,否则对#[message.inboundProperties['City']]的评估只能返回null

案例:

  

====输入test2数据====== null   是不同的。它来自:

<logger message="==== Input test2 data    ======#[payload.City]" level="INFO" doc:name="Logger"/>

这会在.City类型的有效负载上调用String,但无法正常工作。我推断有效载荷的类型为String

public String dataMapping(@Payload String content)

如果要从中提取值,则需要将JSON字符串有效内容转换为java.util.Map。从doc您可以看到您需要添加变换器:

<json:json-to-object-transformer returnClass="java.util.Map" />

答案 1 :(得分:0)

使用Java地图,然后在记录器中使用点操作打印它们,它将起作用。