如何在Mule中使用XPATH函数

时间:2014-11-16 11:59:29

标签: xml soap xpath mule mule-studio

我有一个输入SOAP XML,如下所示: -

<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:v1="http://services.test.com/schema/MainData/V1">
   <soapenv:Header>
    </soapenv:Header>
   <soapenv:Body>
      <v1:retrieveDataRequest>
         <v1:Id>662</v1:Id>
      </v1:retrieveDataRequest>
   </soapenv:Body>
</soapenv:Envelope>

现在我的问题很简单......

如何在Mule中使用XPath函数,如count(),name(),substring()等

我想在此SOAP请求中使用XPATH,如下所示: -

 <logger message="#[xpath('count(//v1:retrieveDataRequest/v1:Id)')]" level="INFO" doc:name="Logger"/>

但它抛出以下异常: -

Exception stack is:
1. No Such Function {http://www.mulesoft.org/schema/mule/core}:count (org.jaxen.UnresolvableException)
  org.jaxen.SimpleFunctionContext:127 (null)
2. Failed to evaluate XPath expression: "count(//v1:retrieveDataRequest/v1:Id)" (org.mule.api.MuleRuntimeException)
  org.mule.module.xml.expression.AbstractXPathExpressionEvaluator:141 (http://www.mulesoft.org/docs/site/current3/apidocs/org/mule/api/MuleRuntimeException.html)
3. org.mule.api.MuleRuntimeException: Failed to evaluate XPath expression: "count(//v1:retrieveDataRequest/v1:Id)" (java.lang.RuntimeException)
  org.mule.module.xml.el.XPathFunction:70 (null)
4. [Error: org.mule.api.MuleRuntimeException: Failed to evaluate XPath expression: "count(//v1:retrieveDataRequest/v1:Id)"]
[Near : {... xpath('count(//v1:retrieveData ....}]
             ^
[Line: 1, Column: 1] (org.mule.mvel2.CompileException)
  org.mule.mvel2.optimizers.impl.refl.ReflectiveAccessorOptimizer:437 (http://www.mulesoft.org/docs/site/current3/apidocs/org/mule/mvel2/CompileException.html)
5. Execution of the expression "xpath('count(//v1:retrieveDataRequest/v1:Id)')" failed. (org.mule.api.expression.ExpressionRuntimeException)
  org.mule.el.mvel.MVELExpressionLanguage:202 (http://www.mulesoft.org/docs/site/current3/apidocs/org/mule/api/expression/ExpressionRuntimeException.html)
6. Execution of the expression "xpath('count(//v1:retrieveDataRequest/v1:Id)')" failed. (org.mule.api.expression.ExpressionRuntimeException). Message payload is of type: String (org.mule.api.MessagingException)
  org.mule.execution.ExceptionToMessagingExceptionExecutionInterceptor:32 (http://www.mulesoft.org/docs/site/current3/apidocs/org/mule/api/MessagingException.html)
--------------------------------------------------------------------------------
Root Exception stack trace:
org.jaxen.UnresolvableException: No Such Function {http://www.mulesoft.org/schema/mule/core}:count
    at org.jaxen.SimpleFunctionContext.getFunction(SimpleFunctionContext.java:127)
    at org.jaxen.ContextSupport.getFunction(ContextSupport.java:242)
    at org.jaxen.Context.getFunction(Context.java:216)
    + 3 more (set debug level logging or '-Dmule.verbose.exceptions=true' for everything)

请注意: - 我已经使用 Mule namespace-manager ,如下所示: -

<mulexml:namespace-manager includeConfigNamespaces="true">
    <mulexml:namespace prefix="soapenv" uri="http://schemas.xmlsoap.org/soap/envelope/"/>
    <mulexml:namespace prefix="v1" uri="http://services.test.com/schema/MainData/V1"/>
</mulexml:namespace-manager>

我得到以下结果: - <logger message="#[xpath('//v1:retrieveDataRequest/v1:Id').text]" level="INFO" doc:name="Logger"/>

请帮忙

2 个答案:

答案 0 :(得分:3)

您未在上面显示的异常的相关位是:

Root Exception stack trace:
org.jaxen.UnresolvableException: No Such Function {http://www.mulesoft.org/schema/mule/core}:count
at org.jaxen.SimpleFunctionContext.getFunction(SimpleFunctionContext.java:127)
at org.jaxen.ContextSupport.getFunction(ContextSupport.java:242)
at org.jaxen.Context.getFunction(Context.java:216)
    + 3 more (set debug level logging or '-Dmule.verbose.exceptions=true' for everything)

如您所见,在Mule名称空间中评估count XPath函数。这是在includeConfigNamespaces="true"中使用namespace-manager的副作用。您似乎不需要Mule命名空间来评估您的XPath(您在SOAP消息中没有使用任何Mule命名空间),因此您应该将此值设置为false。

这将在Mule 3.6中按MULE-7030修复。

答案 1 :(得分:1)

所以,根据David的建议......最终的工作解决方案是设置includeConfigNamespaces="false": -

<mulexml:namespace-manager includeConfigNamespaces="false">
    <mulexml:namespace prefix="soapenv" uri="http://schemas.xmlsoap.org/soap/envelope/"/>
    <mulexml:namespace prefix="v1" uri="http://services.test.com/schema/MainData/V1"/>
</mulexml:namespace-manager>

现在,我可以使用像count()这样的XPATH函数,而不会出现任何问题: -

<logger message="#[xpath('count(//v1:retrieveDataRequest/v1:Id)')]" level="INFO" doc:name="Logger"/>