У меня проблема с одним корпусом в Mule 3.9. У меня есть API, созданный с помощью файла .this .raml. Одна из конечных точек - это просто GET с маршрутом "/" (для целей тестирования). В этом потоке (управление GET/) я хотел бы вызвать другой поток для проверки sth (в моем случае проверка JWT). Когда это действительно, я хотел бы передать и вернуть полезную нагрузку источника. Когда недействительно, я вызываю исключение в Groovy, что действительно происходит, но ведь речь идет об одной и той же исходной полезной нагрузке, которая не должна быть видна.

Давайте сделаем код:

Исходный поток:

        <flow-ref name="validate_jwt_token" doc:name="Validate JWT"/>

        <set-payload value=" { &quot;message&quot; : &quot;API is working!&quot;}" doc:name="Set Payload" mimeType="application/json" />
    </flow>

И ссылка на поток:

<flow name="validate_jwt_token">
        <logger message="Request found with Authorization: #[message.inboundProperties['authorization']]" level="INFO" doc:name="Loger Authorization"/>
        <component doc:name="Validate JWT Token">
            <spring-object bean="ValidateJWTEvent"/>
        </component>
        <choice doc:name="Choice">
             <when expression="(payload == true)">
                <logger message="JWT valid. Access granted." level="INFO" doc:name="Logger"/>
            </when>
             <otherwise>

                <scripting:component doc:name="Throw Exception">
                    <scripting:script engine="Groovy"><![CDATA[throw new Exception('Invalid JWT Token.')]]></scripting:script>
                </scripting:component>
            </otherwise>
        </choice>
          <catch-exception-strategy doc:name="Catch Exception Strategy">
            <set-property propertyName="http.status" value="401" doc:name="Set 401 status"/>
            <flow-ref name="commons.exceptionStrategy.logError" doc:name="Log errors"/>
        </catch-exception-strategy>


    </flow>

И даже если этот токен на самом деле недействителен, я получаю ту же полезную нагрузку с текстом «API IS WORKING». Что я хочу сделать, так это поймать исключение и вернуть HTTP ERROR. Больше ничего.

Я также прилагаю свою Exception-Strategy. Пожалуйста, имейте в виду, что он основан на APIKIT, сгенерированном моим Mule файлом .raml.

 <sub-flow name="commons.exceptionStrategy.logError">
        <logger message="Error: #[exception.?cause.message or exception]" level="ERROR" doc:name="Logger" />

        <set-property propertyName="Content-Type" value="application/json" doc:name="Set Content Type"/>
        <flow-ref name="log_params" doc:name="log_params"/>
        <logger message="#[org.apache.commons.lang3.StringEscapeUtils.escapeJson(exception.?getCauseException().?getMessage())]" level="ERROR" doc:name="Display error"/>
        <set-payload value="{ &quot;responseHeader&quot;: { &quot;requestId&quot;: &quot;#[flowVars.storedRequestId]&quot;, &quot;sendDate&quot;: &quot;#[function:now]&quot;}, &quot;code&quot;: &quot;#[flowVars.'statusCode']&quot;, &quot;message&quot;: &quot;#[flowVars.errorMessage or org.apache.commons.lang3.StringEscapeUtils.escapeJson(exception.?getCauseException().?getMessage())]&quot; }" doc:name="Set Error Message"/>
     </sub-flow>

 <sub-flow name="log_params">

<logger message="API| endpoint executed with payload: #[message.payload]" level="INFO" doc:name="log payload"/>
        <logger message="API| endpoint executed with flowVars: #[flowVars]" level="INFO" doc:name="log params"/>

        </sub-flow>

Весь API используется APIKIT my Mule со стратегией Global Catch Exception.

Пожалуйста, помогите мне, ребята.

0
deyvw 23 Мар 2020 в 17:36
Пожалуйста, покажите стратегию исключения, чтобы понять, как обрабатывается ошибка.
 – 
aled
23 Мар 2020 в 22:44
Сделанный. Я отредактировал этот пост выше.
 – 
deyvw
25 Мар 2020 в 14:41

1 ответ

Похоже, вы ловите исключение в том же потоке, в котором вы его выбрасываете. Поэтому оно не распространяется и поток не прерывается, так как исключение обрабатывается. Вместо этого попробуйте использовать стратегию исключения отката, которая изменит полезную нагрузку, но распространит исключение на ссылку потока вызывающей стороны и прервет этот поток. ХТН

1
afelisatti 4 Апр 2020 в 00:58