<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
为什么我在这里得到空值?
答案 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地图,然后在记录器中使用点操作打印它们,它将起作用。