我有一个骆驼'seda'路线,大致包含代码:
JaxbDataFormat jaxb = new JaxbDataFormat(false);
jaxb.setContextPath("com.example.data.api");
from("seda:validate")
.marshal(jaxb)
.to("spring-ws:" + getDataServiceURL())
.unmarshal(jaxb)
我从 com.example.data.api 发送一个对象,JaxbDataFormat 格式化程序将其设置为 SOAP 请求,并将它传递给 wo spring-ws 以实际发送到我的服务。大多数时候,这就像一个魅力。
我说“大多数”是因为 spring-ws 时不时地抛出一个异常,如下所示:
org.springframework.ws.client.WebServiceTransformerException: Transformation error: Can't transform a Source of type javax.xml.transform.stax.StAXSource; nested exception is javax.xml.transform.TransformerException: Can't transform a Source of type javax.xml.transform.stax.StAXSource
at org.springframework.ws.client.core.WebServiceTemplate.doSendAndReceive(WebServiceTemplate.java:608)
at org.springframework.ws.client.core.WebServiceTemplate.sendAndReceive(WebServiceTemplate.java:537)
at org.springframework.ws.client.core.WebServiceTemplate.doSendAndReceive(WebServiceTemplate.java:492)
at org.springframework.ws.client.core.WebServiceTemplate.sendSourceAndReceive(WebServiceTemplate.java:479)
at org.springframework.ws.client.core.WebServiceTemplate.sendSourceAndReceive(WebServiceTemplate.java:470)
at org.apache.camel.component.spring.ws.SpringWebserviceProducer.process(SpringWebserviceProducer.java:81)
at org.apache.camel.util.AsyncProcessorConverterHelper$ProcessorToAsyncProcessorBridge.process(AsyncProcessorConverterHelper.java:61)
at org.apache.camel.util.AsyncProcessorHelper.process(AsyncProcessorHelper.java:73)
其核心是此错误消息:“无法转换 javax.xml.transform.stax.StAXSource 类型的源”。
这些都没有意义。Jaxb 编组已经确保所讨论的对象是一个 XML 字符串(根据我所做的任何调试日志记录)。此外,这个确切的代码大部分时间都可以工作,只是偶尔会失败。它看起来是随机的。
例如,几分钟前我运行了一个测试,我在我的路由中发送了一条消息并收到了这个错误。然后我重新启动我的服务并重新发送完全相同的消息......它就像一个魅力。相同的代码;相同的环境;同样的测试——两个不同的结果。
正是这种随机性让这一切变得如此令人抓狂。我应该寻找什么以确保这永远不会发生的任何想法?