WSO2 ESB-从错误访问原始消息

WSO2 ESB-从错误访问原始消息,wso2,wso2esb,Wso2,Wso2esb,我的目标是将返回soap错误的消息放到队列中,以便稍后重试 我几乎完成了所有工作,但最重要的是:我无法从代理的故障序列访问原始消息:( 我首先创建了一个代理服务,它为给定值返回一个错误,或为其他值返回OK: <?xml version="1.0" encoding="UTF-8"?> <proxy xmlns="http://ws.apache.org/ns/synapse" name="TestProxyService" transports="http https" sta

我的目标是将返回soap错误的消息放到队列中,以便稍后重试

我几乎完成了所有工作,但最重要的是:我无法从代理的故障序列访问原始消息:(

我首先创建了一个代理服务,它为给定值返回一个错误,或为其他值返回OK:

<?xml version="1.0" encoding="UTF-8"?>
<proxy xmlns="http://ws.apache.org/ns/synapse" name="TestProxyService" transports="http https" startOnLoad="true" trace="disable">
    <target>
        <inSequence>
            <log level="custom">
                <property name="TestProxyService" value="InSequence"/>
            </log>
            <switch xmlns:bnc="http://bnc.org/" source="//bnc:id">
                <case regex="1">
                    <log level="custom">
                        <property name="TestProxyService" value="Send Error !"/>
                    </log>
                    <makefault version="soap11">
                        <code xmlns:soap11Env="http://schemas.xmlsoap.org/soap/envelope/" value="soap11Env:VersionMismatch"/>
                        <reason value="ERROR ERROR ERROR"/>
                        <detail>ERROR</detail>
                    </makefault>
                    <respond/>
                </case>
                <default>
                    <log level="custom">
                        <property name="TestProxyService" value="No Error"/>
                    </log>
                    <log level="custom">
                        <property name="id" expression="//bnc:id"/>
                    </log>
                    <payloadFactory media-type="xml">
                        <format>
                            <bnc:response>OK</bnc:response>
                        </format>
                        <args/>
                    </payloadFactory>
                    <respond/>
                </default>
            </switch>
        </inSequence>
        <outSequence/>
        <faultSequence/>
    </target>
</proxy>


错误
好啊
而且效果很好

然后,我制作了另一个代理,它使用第一个代理作为端点来测试出错时的队列:

<?xml version="1.0" encoding="UTF-8"?>
<proxy xmlns="http://ws.apache.org/ns/synapse" name="QueuingProxyService" transports="https http" startOnLoad="true" trace="disable">
    <target>
        <inSequence>
            <property name="FORCE_ERROR_ON_SOAP_FAULT" value="true" scope="default" type="STRING"/>
            <send>
                <endpoint key="TestProxyServiceEndpoint"/>
            </send>
        </inSequence>
        <outSequence>
            <send/>
        </outSequence>
        <faultSequence>
            <store messageStore="No1MessageStore"/>
            <makefault version="soap11">
                <code xmlns:soap11Env="http://schemas.xmlsoap.org/soap/envelope/" value="soap11Env:VersionMismatch"/>
                <reason value="There has been an error"/>
                <detail>We will retry later</detail>
            </makefault>
            <send/>
        </faultSequence>
    </target>
</proxy>


我们将稍后重试
存储的消息是由TestProxy中的makefault生成的消息

我试图用


但在faultSequence中,当我这样做时:

<log level="custom">
    <property name="OriginalBody" expression="get-property('OriginalBody')"/>
</log>

结果我得到空值:(

有人有主意吗

谢谢!

在定义属性“OriginalBody”或明确指定scope=“default”时删除作用域“axis2”:


<log level="custom">
    <property name="OriginalBody" expression="get-property('OriginalBody')"/>
</log>
<property name="OriginalBody" expression="$body" type="OM"/>