将数据库表中的值设置为输出HTTP标头

时间:2015-12-13 09:04:35

标签: mule esb mel

我是骡子ESB的新手。 我需要设置HTTP头,其中值应从MySQLDB中获取。我可以从DB中获取值。 DB返回多行列值。

我可以在流变量(flowVars)中设置一个列值,并且可以在HTTP头中设置。但是,如果我必须在每个HTTP头中设置多个列变量,将导致我编写多个set变量命令。

如何避免编写多个set变量命令? (是否有任何mule表达式通过单个命令设置多个变量?)有没有其他简单的方法来实现这一点?

<flow name="mule_eeFlow">
    <http:listener config-ref="HTTP_Input_eba_Listener_Configuration" path="/XXX/additem" doc:name="HTTP"/>
    <db:select config-ref="MySQL_Configuration" doc:name="Database">
        <db:template-query-ref name="Template_Query"/>
    </db:select>
    <set-variable variableName="LEVEL" value="#[message.payload[0].'X-API-COMPATIBILITY-LEVEL']" doc:name="Variable"/>
    <set-variable variableName="DEVNAME" value="#[message.payload[0].'X-API-DEV-NAME']" doc:name="Variable"/>
    <set-variable variableName="APPNAME" value="#[message.payload[0].'X-API-APP-NAME']" doc:name="Variable"/>
    <set-variable variableName="CERTNAME" value="#[message.payload[0].'X-API-CERT-NAME']" doc:name="Variable"/>
    <set-variable variableName="SITEID" value="#[message.payload[0].'X-API-SITEID']" doc:name="Variable"/>
    <set-variable variableName="CALLNAME" value="#[message.payload[0].'X-API-CALL-NAME']" doc:name="Variable"/>

    <custom-transformer class="AddingHTTPHeader" doc:name="Java"/>
</flow>

我的Java代码看起来像

@Override
public Object transformMessage(MuleMessage message, String outputEncoding)
        throws TransformerException {
    // TODO Auto-generated method stub
    message.setOutboundProperty("X-API-COMPATIBILITY-LEVEL", message.getInvocationProperty("LEVEL"));
    message.setOutboundProperty("X-API-DEV-NAME", message.getInvocationProperty("DEVNAME"));
    message.setOutboundProperty("X-API-APP-NAME", message.getInvocationProperty("APPNAME"));
    message.setOutboundProperty("X-API-CERT-NAME", message.getInvocationProperty("CERTNAME"));
    message.setOutboundProperty("X-API-SITEID", message.getInvocationProperty("SITEID"));
    message.setOutboundProperty("X-API-CALL-NAME", message.getInvocationProperty("CALLNAME"));

    return null;
}

2 个答案:

答案 0 :(得分:0)

您可以直接在Mule中设置出站属性,而无需使用变量和Java代码,有多种方法可以执行此操作。

使用&#39;设置属性&#39;变压器

https://docs.mulesoft.com/mule-fundamentals/v/3.7/message-state#setting-a-property-on-a-message

https://docs.mulesoft.com/mule-user-guide/v/3.7/property-transformer-reference

或者,如果将EE与DataWeave一起使用,则可以在DataWeave中设置所有属性,并仅使用一个DataWeave转换器创建它们,而不是添加单独的属性转换器。

https://docs.mulesoft.com/mule-user-guide/v/3.7/using-dataweave-in-studio#handling-multiple-outputs

答案 1 :(得分:0)

谢谢你的回答! 这有助于我获得“消息属性”功能。这有助于我删除java代码并设置变量。这个函数帮我设置了多个http标题。

<message-properties-transformer doc:name="Message Properties">
        <add-message-property key="X-API-COMPATIBILITY-LEVEL" value="#[message.payload[0].'X-API-COMPATIBILITY-LEVEL']"/>
        <add-message-property key="X-API-DEV-NAME" value="#[message.payload[0].'X-API-DEV-NAME']"/>
        <add-message-property key="X-API-APP-NAME" value="#[message.payload[0].'X-API-APP-NAME']"/>
        <add-message-property key="X-API-CERT-NAME" value="#[message.payload[0].'X-API-CERT-NAME']"/>
        <add-message-property key="X-API-SITEID" value="#[message.payload[0].'X-API-SITEID']"/>
        <add-message-property key="X-API-CALL-NAME" value="#[message.payload[0].'X-API-CALL-NAME']"/>
    </message-properties-transformer>