我在 Web 服务的客户端实现方面遇到了一些问题。我有 wsdl,并使用 wsimport 工具创建了类。
当我通过这些类调用 web 服务时,我可以在日志中看到请求和响应......看起来还不错。我不能使用这些类来处理从 WS 接收到的数据,因为结果对象没有关于它包含的字段的定义......
因此,我试图从 WebService 获得原始响应......我通过附加一个 SoapHandler 来做到这一点:
BindingProvider bindingProvider = (BindingProvider)port;
List<Handler> handlerChain = new ArrayList<Handler>();
handlerChain.add(new SoapMsgHandler());
bindingProvider.getBinding().setHandlerChain(handlerChain);
result = port.getXmlFromWS();
....
在处理程序中,我实现了 handleMessage(SOAPMessageContext context) 方法来将消息打印到日志,但我遇到了一个问题......
下面是应该处理响应的 Handler 类的一部分......但我在这一行得到一个异常: SOAPMessage message = smc.getMessage()
例外情况如下:
org.w3c.dom.DOMException: WRONG_DOCUMENT_ERR: A node is used in a different document than the one that created it.
at org.apache.xerces.dom.ParentNode.internalInsertBefore(Unknown Source)
at org.apache.xerces.dom.ParentNode.insertBefore(Unknown Source)
at org.apache.xerces.dom.CoreDocumentImpl.insertBefore(Unknown Source)
at org.apache.xerces.dom.NodeImpl.appendChild(Unknown Source)
at org.jboss.ws.core.soap.SOAPDocument.appendChild(SOAPDocument.java:222)
at org.jboss.ws.core.soap.SOAPPartImpl.appendChild(SOAPPartImpl.java:297)
at com.sun.xml.bind.marshaller.SAX2DOMEx.startElement(SAX2DOMEx.java:176)
at com.sun.xml.ws.encoding.TagInfoset.writeStart(TagInfoset.java:168)
at com.sun.xml.ws.message.stream.StreamMessage.writeTo(StreamMessage.java:442)
at com.sun.xml.ws.message.AbstractMessageImpl.readAsSOAPMessage(AbstractMessageImpl.java:193)
at com.sun.xml.ws.handler.SOAPMessageContextImpl.getMessage(SOAPMessageContextImpl.java:79)
处理程序实现的一部分:
import javax.xml.soap.SOAPMessage;
import javax.xml.ws.handler.MessageContext;
import javax.xml.ws.handler.soap.SOAPHandler;
import javax.xml.ws.handler.soap.SOAPMessageContext;
public class SoapMsgHandler implements SOAPHandler<SOAPMessageContext> {
@Override
public boolean handleMessage(SOAPMessageContext context) {
printTheMsg(context);
return true;
}
private void printTheMsg(SOAPMessageContext smc) {
SOAPMessage message = smc.getMessage(); //this line produces the mentioned exception
....
}
....
}
任何有关可能出错的帮助将不胜感激。