我在我的流程中有一个"Catch Exception Strategy",我使用SMTP连接器向管理员(我)发送电子邮件。
我能够使用#[exception]
发送异常,但我想发送更详细的消息,包括:
- 完整的URL请求
- 发送的原始有效载荷
- 转换有效载荷
- (可选,但将是伟大的)完整的堆栈跟踪和错误的时间,如在控制台中。
我尝试使用表达式组件和变量来存储这些信息。我也尝试了变量组件,但也不起作用。在消息中,我的所有变量总是被设置为null。
这是我的流程:
<flow name="PivotalContactById" >
<https:inbound-endpoint connector-ref="HTTP_HTTPS" exchange-pattern="request-response" host="host" port="port" doc:name="HTTP (Deprecated)" path="path"/>
<logger level="INFO" message="#[message.payloadAs(java.lang.String)]" doc:name="Logger"/>
<set-variable variableName="flowVars.url" value="#[message.inboundProperties.'http.context.url']" doc:name="Variable"/>
<set-variable variableName="flowVars.originalPayload" value="#[payload]" doc:name="Variable"/>
<json:json-to-object-transformer returnClass="java.util.Map" doc:name="JSON to Object"/>
<scripting:component doc:name="GroovyContactIDJsonToXML">
<scripting:script engine="Groovy" file="pivotalContactById_JSON_to_XML.groovy"></scripting:script>
</scripting:component>
<logger level="INFO" message="#[message.payloadAs(java.lang.String)]" doc:name="Logger"/>
<set-variable variableName="flowVars.convertedPayload" value="#[payload]" doc:name="Variable"/>
<ws:consumer config-ref="Web_Service_Consumer1" operation="GetContactById" doc:name="Pivotal SOAP Web Service"/>
<logger level="INFO" message="#[message.payloadAs(java.lang.String)]" doc:name="Logger"/>
<catch-exception-strategy doc:name="Catch Exception Strategy">
<set-payload value="#[exception] #[flowVars.url] #[flowVars.originalPayload] #[flowVars.convertedPayload]" doc:name="Set Payload"/>
<smtp:outbound-endpoint host="host" to="dude@dude.org" from="adminmule@dude.org" subject="Exception yo" responseTimeout="10000" doc:name="SMTP"/>
</catch-exception-strategy>
</flow>
在flow Level中,请单独提供variableName = url(而不是flowVars.url)。当在Catch Exception Strategy设置为#[flowVars.url]
或#[flowVars['url']]
时访问它