Mule Studio Как создать глобальную переменную

нажмите, чтобы увидеть мое изображение потока

Мое тестовое приложение мула. Я использую данные записи curl json для http-end-point и преобразовываю json в объект и вставляю в свою базу данных с именем (#[message.payload.name])

Я использую стратегию catch-exception для ведения журнала ошибок (уникальное имя случая)

Я хочу обновить свою таблицу с условием в поле #[message.payload.name] - означает, что Update mytable set Firstname = #[message.payload.name]

но в стратегии catch-exception нет доступа к #[message.payload.name]

Моя конфигурация

  <?xml version="1.0" encoding="UTF-8"?>

<mule xmlns:jdbc-ee="http://www.mulesoft.org/schema/mule/ee/jdbc" xmlns:data-mapper="http://www.mulesoft.org/schema/mule/ee/data-mapper" xmlns:http="http://www.mulesoft.org/schema/mule/http"
    xmlns:json="http://www.mulesoft.org/schema/mule/json"
    xmlns="http://www.mulesoft.org/schema/mule/core" xmlns:doc="http://www.mulesoft.org/schema/mule/documentation" xmlns:spring="http://www.springframework.org/schema/beans" version="EE-3.3.2" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="
http://www.mulesoft.org/schema/mule/json http://www.mulesoft.org/schema/mule/json/current/mule-json.xsd 
http://www.mulesoft.org/schema/mule/http http://www.mulesoft.org/schema/mule/http/current/mule-http.xsd 
http://www.mulesoft.org/schema/mule/ee/jdbc http://www.mulesoft.org/schema/mule/ee/jdbc/current/mule-jdbc-ee.xsd 
http://www.mulesoft.org/schema/mule/ee/data-mapper http://www.mulesoft.org/schema/mule/ee/data-mapper/current/mule-data-mapper.xsd 
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-current.xsd 
http://www.mulesoft.org/schema/mule/core http://www.mulesoft.org/schema/mule/core/current/mule.xsd ">
    <data-mapper:config name="Mapper" transformationGraphPath="mapper.grf" doc:name="DataMapper"></data-mapper:config>
    <jdbc-ee:mysql-data-source name="MySQL_Data_Source1" url="jdbc:mysql://localhost:3306/mule" user="root" password="1234" transactionIsolation="UNSPECIFIED" doc:name="MySQL Data Source"/>
    <jdbc-ee:connector name="Database" dataSource-ref="MySQL_Data_Source1" validateConnections="true" queryTimeout="-1" pollingFrequency="0" doc:name="Database"/>
    <flow name="httpPostTestFlow1" doc:name="httpPostTestFlow1"> 
        <http:inbound-endpoint exchange-pattern="request-response" host="localhost" port="8081" path="httpPost" doc:name="httpPost"></http:inbound-endpoint>

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


                <jdbc-ee:outbound-endpoint exchange-pattern="one-way" queryKey="INSERT_TOKEN"  connector-ref="Database" doc:name="Database">
                    <jdbc-ee:query key="INSERT_TOKEN" value="insert into users(FirstName) values(#[message.payload.name]);"/>
                </jdbc-ee:outbound-endpoint>


              <!--  <http:outbound-endpoint exchange-pattern="request-response" host="localhost" port="80" path="post-debug.php" contentType="application/x-www-form-urlencoded" doc:name="post-debug.php"/> --> 


         <catch-exception-strategy doc:name="Catch Exception Strategy">
            <expression-component doc:name="Create error response">#[message.payload = "{\"status\":\"error\", \"message\":\"" + exception.cause.message + "\"}"]</expression-component>
            <jdbc-ee:outbound-endpoint exchange-pattern="one-way"   connector-ref="Database" doc:name="Database" queryTimeout="-1" queryKey="UPDATE_TOKEN">
                    <jdbc-ee:query key="UPDATE_TOKEN" value="update users SET fail_message = #[message.payload]"/>
                </jdbc-ee:outbound-endpoint>
        </catch-exception-strategy>


    </flow>
</mule>

person Panup Pong    schedule 22.02.2013    source источник


Ответы (1)


Основываясь на заголовке, вы хотите иметь какую-то глобальную переменную, один из способов — попробовать использовать flowVars в качестве быстрого исправления. Используя Mule Studio, это то же самое, что и Variable (в Transformers).

Сообщение, которое вы получаете внутри стратегии исключения исключения, является исключением.

person Ian    schedule 22.02.2013
comment
меньше документа , большое спасибо - person Panup Pong; 22.02.2013