MULE:如何在MEL中使用CDATA

时间:2013-11-14 12:34:33

标签: mule mule-studio mel mule-el

请帮我解决这个错误。我已经通过mainflow中的会话变量捕获了原始有效负载。如果出现错误情况,我有另一个子流,我使用了Message Property TransformerXSLT transformer。所以,当我尝试放错格式的xml(试图创建解析器异常)。在XSLT变换器抛出错误,如“元素类型”messageNamestr1234“必须跟随属性规范,”>“或”/>“”。 / p>

实际上我的逻辑是,在错误的情况下,我应该构建xml - 在其中一个需要捕获original payload。在所有其他测试场景中它似乎工作正常(正确生成xml) 。但是仅对于解析器异常,消息不会传播到队列,因为XSLT抛出错误。请找我的配置xml

        <flow name="mainFlow" doc:name="MessageFlow"
    tracking:enable-default-events="true">

    <wmq:inbound-endpoint queue="InQUEUE"
        tracking:enable-default-events="true" connector-ref="WMQ_Connector"
        doc:name="queue" doc:description="Flow">
        <wmq:transaction action="ALWAYS_BEGIN" />
    </wmq:inbound-endpoint>
    <byte-array-to-string-transformer doc:name="Byte Array to String"/>
    <set-session-variable variableName="originalPayload" value="#[payload]" doc:name="Store_Payload"/> 
    <logger message="***change*#[message.payloadAs(java.lang.Object)]*****" level="INFO" doc:name="Logger"/>
    <mulexml:dom-to-xml-transformer></mulexml:dom-to-xml-transformer>
              <set-session-variable variableName="operation"
        value="#[xpath('fn:local-name(/root/*[2])')]" doc:name="Set_Operation" doc:description="separate Operation"/>       
    ..........
    <choice-exception-strategy doc:name="Choice Exception Strategy" doc:description="used to differenciate system and application error">
        <catch-exception-strategy doc:name="Catch_ApplicationFailure_Messages"
            when="#[exception.causedBy(org.mule.api.MessagingException)]" doc:description="Catches all the application errors and call the error handling subflow to log the error messages">
            <flow-ref name="Common_ErrorHandling_SubFlow" doc:name="Invoke_Common_ErrorHandling_SubFlow" />
        </catch-exception-strategy>

        <rollback-exception-strategy
            maxRedeliveryAttempts="3" doc:name="Catch_SystemFailure_Messages" doc:description="Message Processor catches system error and tries to retry for 3 times and finally put the message in queue"> 
        ................        
        </rollback-exception-strategy>
    </choice-exception-strategy>
</flow>

     <sub-flow name="Common_ErrorHandling_SubFlow" doc:name="Common_ErrorHandling_SubFlow"
    tracking:enable-default-events="true">

    <logger message="***enetered**" level="INFO" doc:name="Logger"/>

    <message-properties-transformer
        doc:name="Catch_MessageProperties" doc:description="Used to capture project and message specific information" scope="outbound">

        <add-message-property key="InterfaceName" value="'Requests'" />
        <add-message-property key="ProjectName" value="'NewProject'" />
        ..........
        <add-message-property key="JMSMessageID"
            value="#[header:INBOUND:JMSMessageID]" />
        <add-message-property key="MuleMessageID"
            value="#[header:INBOUND:MULE_MESSAGE_ID]" />
        <add-message-property key="ExceptionPayload"
            value="#[exception]" />
        <add-message-property key="originalPayload" value="#[sessionVars.originalPayload]"/>
    </message-properties-transformer>
    <byte-array-to-string-transformer doc:name="Byte Array to String"/>

    <mulexml:xslt-transformer
        maxIdleTransformers="2" maxActiveTransformers="5"
        doc:name="Generate_ErrorXmlStructure" xsl-file="XSLTScript.txt" doc:description="XSLT transformer used to generate standard xml message with its scripts">
        <mulexml:xslt-text>
        </mulexml:xslt-text>

        <mulexml:context-property key="ProjectName"
            value="#[header:OUTBOUND:ProjectName]" />
        .........
        <mulexml:context-property key="DetailsExceptionMessage"
            value="#[header:OUTBOUND:DetailsExceptionMessage]" />
        <mulexml:context-property key="OriginalPayload"
            value="#[header:OUTBOUND:originalPayload]" />
        <mulexml:context-property key="MessageInDate"
            value="#[header:OUTBOUND:MessageInDate]" />
        <mulexml:context-property key="InputQueue"
            value="#[header:OUTBOUND:InputQueue]" />
    </mulexml:xslt-transformer>

    <wmq:outbound-endpoint queue="ERROR"
        connector-ref="WMQ_Connector" doc:name=".ERROR" doc:description="Used to log error messages">
        <wmq:transaction action="ALWAYS_JOIN"/>
    </wmq:outbound-endpoint>
</sub-flow>

假设:因为它是解析器异常,XSLT Transformer除了标准xml结构(捕获有效负载)。所以考虑在CDATA中路由。不知道怎么做。还在XSLT变换器的上下文属性中尝试了各种选项

       1. <mulexml:context-property key="OriginalPayload"
            value="#[message.outboundproperies.originalPayloadAs(java.lang.Object)]" /> 
       2.<mulexml:context-property key="OriginalPayload"
            value="#[header:SESSION:originalPayload]" />
       3.<mulexml:context-property key="OriginalPayload"
            value="#[!CDATA[sessionVars.originalPayload]]" />

但没有希望。亲切地帮助我。

@DavidDossot:我添加了我的XLST scipt,我按照你的建议更改了参数。

      <xsl:stylesheet version="2.0"
                    xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
                    <xsl:output omit-xml-declaration="yes" cdata-section-elements="OriginalPayload" />
                    <xsl:param name="InterfaceName" />
                    <xsl:param name="ProjectName" />
                       ..........
                    <xsl:param name="OriginalPayload" />
                    <xsl:param name="MessageInDate" />
                    <xsl:template match="*">
                        <Specific>
                            <ProjectName>
                                <xsl:value-of select="$ProjectName" />
                            </ProjectName>
                            <InterfaceName>
                                <xsl:value-of select="$InterfaceName" />
                            </InterfaceName>
                                .......
                           <OriginalPayload>
                            <xsl:value-of select="$OriginalPayload"/>
                        </OriginalPayload> 
                 </Specific>
                    </xsl:template>
                </xsl:stylesheet>

也在我添加的上下文属性中

                    <mulexml:context-property key="OriginalPayload"
            value="#[sessionVars.originalPayload]" />

我还是面临同样的错误。我已经尝试了多个选项1.删除了omit-xml-declaration 2.在xslt中编辑了很多属性并尝试过。没有希望。请指导我出错的地方。

@DavidDossot请找到我的输入xml(从messageName中删除&gt;以检查流中的解析器异常行为)

   <?xml version="1.0" encoding="utf-8"?>
   <root>
   <header>
   <messageName>str1234</messageName>
   <messageId>12345</messageId>
   <storeNo>123</storeNo>
   <storeElement>str1</storeElement>
   <requestDateTime>2012-12-13T12:12:12</requestDateTime>
   </header>
   <Request>
   <messageNamestr1234</messageName>
   </Request>
   </root>

请指导我。

1 个答案:

答案 0 :(得分:1)

由于原始有效负载是一个字符串,您应该能够直接将其传递给XSL-T:

<mulexml:context-property key="OriginalPayload"
        value="#[sessionVars.originalPayload]" />

然后在XSL output configuration中,将包含原始有效负载的XML元素的名称放在cdata-section-elements中:

<xsl:output cdata-section-elements="yourElementNameHere"/>

PS。不推荐header:OUTBOUND使用message.outboundProperties