首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Camel未使用camel-cxf正确拦截SoapFault

Camel未使用camel-cxf正确拦截SoapFault
EN

Stack Overflow用户
提问于 2015-04-28 19:31:34
回答 1查看 1.3K关注 0票数 3

我需要帮助。我不能得到我的web服务抛出的异常,我不知道为什么。

我已经在camel中创建了一个简单的路由,我希望捕获来自web服务的错误消息作为异常,并解释错误。

路由如下:

代码语言:javascript
复制
    onException(Exception.class)
        .handled(true)
        .to("log:info")
        .process(new FailureResponseProcessor())
        .to("file:data/outbox?fileName=error.xml");

    from("file:data/inbox?noop=true")   
        .process(loggerProcessor)
        .to("cxf://http://localhost:8080/TestWebService?dataFormat=PAYLOAD"
          + "&properties.exceptionMessageCauseEnabled=true"
          + "&properties.faultStackTraceEnabled=true")
        .to("file:data/outbox?fileName=response.xml");

在上下文配置中,我有这样的配置:

代码语言:javascript
复制
context.setHandleFault(true);

我为测试而创建的web服务非常简单:

代码语言:javascript
复制
@WebService
public class TestWebService {
    @WebMethod
    public double suma(double a, double b) throws Exception {
        System.out.println("Webservice invocado!!!");
        throw new Exception("Mi excepcion");
        //return a + b;
    }
}

但是我无法从异常"Mi excepcion“中获得消息。

我猜问题来自于下面这行:

代码语言:javascript
复制
2015-04-28 13:05:15 DEBUG DefaultErrorHandler:71 - Failed delivery for (MessageId: ID-saqqara-40731-1430219108400-0-3 on ExchangeId: ID-saqqara-40731-1430219108400-0-2). On delivery attempt: 0 caught: org.apache.cxf.binding.soap.SoapFault: No se ha encontrado el método de distribución de {http://schemas.xmlsoap.org/soap/envelope/}Envelope

因为捕获的异常是我的异常策略是这样的:

代码语言:javascript
复制
Error: No se ha encontrado el método de distribución de {http://schemas.xmlsoap.org/soap/envelope/}Envelope

编辑:

我对代码做了一点修改,以记录更多信息。这是我所做的:

代码语言:javascript
复制
onException(SoapFault.class)
    .handled(true)
    .log("Response ON ERROR: ${body}")
    .log("Response ON FAULT: ${exception}")
    .process(new FailureResponseProcessor())
    .to("file:data/outbox?fileName=error.xml");

from("file:data/inbox?noop=true")
    .id("miRuta")
    .log("File content: ${body}")
    .to("cxf://http://localhost:8080/TestWebService?dataFormat=PAYLOAD"
      + "&properties.exceptionMessageCauseEnabled=true"
      + "&properties.faultStackTraceEnabled=true")
    .log("WS Response: ${body}");

我所发现的是,当异常被捕获时,使用以下行记录的消息:

代码语言:javascript
复制
.log("Response ON ERROR: ${body}")

是这个吗:

代码语言:javascript
复制
2015-04-29 09:53:28 INFO  route1:95 - Response ON ERROR:

<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" 
                  xmlns:test="http://test_ws.testing.com/">
    <soapenv:Header/>
    <soapenv:Body>
        <test:suma>
           <arg0>?</arg0>
           <arg1>?</arg1>
        </test:suma>
    </soapenv:Body>
</soapenv:Envelope>

当它应该是故障消息时,不是吗?

编辑2

XML回复如下:

代码语言:javascript
复制
<?xml version='1.0' encoding='UTF-8'?>
<S:Envelope xmlns:S="http://schemas.xmlsoap.org/soap/envelope/">
    <S:Body>
        <S:Fault xmlns:ns4="http://www.w3.org/2003/05/soap-envelope">
            <faultcode>S:Server</faultcode>
            <faultstring>Mi excepcion</faultstring>
            <detail>
                <ns2:Exception xmlns:ns2="http://test_ws.testing.com/">
                    <message>Mi excepcion</message>
                </ns2:Exception>
            </detail>
        </S:Fault>
    </S:Body>
</S:Envelope>
EN

回答 1

Stack Overflow用户

发布于 2015-04-29 19:41:08

我终于找到了问题所在。

我捕获的xml文件如下:

代码语言:javascript
复制
from("file:data/inbox?noop=true")

包含以下内容:

代码语言:javascript
复制
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:test="http://test_ws.testing.com/">
   <soapenv:Header/>
   <soapenv:Body>
      <test:suma>
         <arg0>5</arg0>
         <arg1>5</arg1>
      </test:suma>
   </soapenv:Body>
</soapenv:Envelope>

错误是由测试web服务正确生成的,但是另一个错误表明没有找到方法信封,这是正确的,因为方法信封不存在于web服务中。存在的方法是"suma“。

因此,我将xml更改为以下内容:

代码语言:javascript
复制
<test:suma xmlns:test="http://test_ws.testing.com/">
  <arg0>5</arg0>
  <arg1>5</arg1>
</test:suma>

我得到了预期的异常:"Mi excepcion“。

无论如何,谢谢你的帮助!

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29918271

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档