问题所在
我正在尝试将我的web服务客户端从Apache AXIS-1迁移到Apache CXF。web服务本身运行om轴-1,并且不受我的控制。
我生成了所有的CXF工件,客户端一直运行良好,直到服务抛出任何错误。有问题的XML如下所示:
<?xml version="1.0" encoding="UTF-8"?>
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/">
<soapenv:Body>
<soapenv:Fault>
<faultcode>soapenv:Server</faultcode>
<faultstring>Remote error processing component card request</faultstring>
<detail>
<fault>
<faultcode>:-303</faultcode>
<faultstring>Remote error processing component card request</faultstring>
<faultactor>remote_service</faultactor>
<detail>
<common-detail>
<code>-303</code>
<message>Remote error processing component card request</message>
</common-detail>
</detail>
</fault>
</detail>
</soapenv:Fault>
</soapenv:Body>
</soapenv:Envelope>
这使得CXF生成的客户端出现异常:
javax.xml.bind.UnmarshalException: unexpected element (uri:"", local:"fault").
Expected elements are <{http://some.namespace.org}AnsBonusAutopayStatus>,<{http://some.namespace.org}AnsBonusAutopaySubscribe>,
...
<{http://some.namespace.org}fault>
at com.sun.xml.bind.v2.runtime.unmarshaller.UnmarshallingContext.handleEvent(UnmarshallingContext.java:603)
at com.sun.xml.bind.v2.runtime.unmarshaller.Loader.reportError(Loader.java:244)
at com.sun.xml.bind.v2.runtime.unmarshaller.Loader.reportError(Loader.java:239)
at com.sun.xml.bind.v2.runtime.unmarshaller.Loader.reportUnexpectedChildElement(Loader.java:116)
at com.sun.xml.bind.v2.runtime.unmarshaller.UnmarshallingContext$DefaultRootLoader.childElement(UnmarshallingContext.java:1009)
at com.sun.xml.bind.v2.runtime.unmarshaller.UnmarshallingContext._startElement(UnmarshallingContext.java:446)
at com.sun.xml.bind.v2.runtime.unmarshaller.UnmarshallingContext.startElement(UnmarshallingContext.java:427)
at com.sun.xml.bind.v2.runtime.unmarshaller.InterningXmlVisitor.startElement(InterningXmlVisitor.java:71)
at com.sun.xml.bind.v2.runtime.unmarshaller.SAXConnector.startElement(SAXConnector.java:137)
at com.sun.xml.bind.unmarshaller.DOMScanner.visit(DOMScanner.java:240)
at com.sun.xml.bind.unmarshaller.DOMScanner.scan(DOMScanner.java:123)
...
从这个堆栈跟踪中,解组程序期望错误元素有特定的名称空间声明,但它没有声明。
有没有人能建议这个客户端出了什么问题,以及如何避免这个错误?
经过测试的解决方案
有很多类似的问题,但并不是所有的解决方案都适用于我,因为我不能更改服务器端的任何东西(至少出于向后兼容性的原因),而且更改WSDL也不受欢迎。因此,更改仅限于客户端(包括其(重新)生成)。基于类似的问题,我尝试了几种可能的解决方案:
使用默认命名空间声明添加package-info.class - nothing changes;
其他信息
CXF为exception生成的类和它的faultInfo (没有我的任何更改)如下所示:
故障类:
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "", propOrder = {
"faultcode",
"faultstring",
"faultactor",
"detail"
})
@XmlRootElement(name = "fault")
public class Fault {
@XmlElement(required = true)
protected String faultcode;
...
Fault_Exception类:
@WebFault(name = "fault", targetNamespace = "http://some.namespace.org")
public class Fault_Exception extends Exception {
private Fault fault;
public Fault_Exception() {
super();
}
...
一些WSDL摘录。WSDL错误消息声明:
<wsdl:message name="Fault">
<wsdl:part name="fault" element="fault"/>
</wsdl:message>
XSD故障元素:
<xs:element name="fault">
<xs:annotation>
<xs:documentation>Comment describing your root element</xs:documentation>
</xs:annotation>
<xs:complexType>
<xs:sequence>
<xs:element name="faultcode">...</xs:element>
<xs:element name="faultstring">...</xs:element>
<xs:element name="faultactor">...</xs:element>
<xs:element minOccurs="0" name="detail">...</xs:element>
</xs:sequence>
</xs:complexType>
</xs:element>
WSDL操作描述示例:
<wsdl:operation name="BonusConversionState">
<wsdl:input name="BonusConversionStateRequest" message="tns:BonusConversionStateRequest"/>
<wsdl:output name="BonusConversionStateResponse" message="tns:BonusConversionStateResponse"/>
<wsdl:fault name="Fault" message="tns:Fault"/>
</wsdl:operation>
WSDL根元素:
<?xml version="1.0" encoding="UTF-8"?>
<wsdl:definitions targetNamespace="http://some.namespace.org"
xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/"
xmlns:tns="http://some.namespace.org"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/">
可以提供更多其他信息。
提前感谢!
编辑:
在“调查”期间,我发现NullPointerException (我在“测试的解决方案”中提到的)并不是我的错误行为的结果。这是CXF的一个错误:
这两个标签都以“修复”的方式关闭,但用户在评论中报告说他们仍然发现了这个错误。似乎开发人员没有涵盖CXF处理自定义异常的所有情况,并且由于某些原因,有时会导致
org.apache.cxf.interceptor.ClientFaultConverter processFaultDetail
信息:创建异常时发生异常:空
java.lang.NullPointerException
有没有人也遇到过这个问题?
发布于 2014-10-14 11:30:45
这似乎是一个服务没有遵守它自己的合同的情况。虽然您可能无法控制服务,但这值得与服务提供商进行讨论。
你的客户抱怨的错误元素是第一个“细节”元素的直接子元素。
根据异常消息,“detail”的第一个子元素应该是(假设目标命名空间为“http://some.namespace.org”) AnsBonusAutopayStatus或AnsBonusAutopaySubscribe,而不是{}错误元素。
如果您能够围绕操作中的错误声明和wsdl类型提供更多的wsdl,那么就可以提供额外的静态分析。
https://stackoverflow.com/questions/26252200
复制相似问题