我正在使用.net中开发的Web服务,该服务接受用户名和密码作为SOAP标头的一部分。我创建了SOAPHandler来创建标题。

我打印了如下消息:

<soapenv:Header xmlns:wsa="http://www.w3.org/2005/08/addressing">
<wsse:Security soapenv:mustUnderstand="1" xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd"
 xmlns:wsu="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd">

 <wsse:UsernameToken>
 <wsse:Username>xxxxxxxxxxx</wsse:Username>
 <wsse:Password>xxxxxxxx</wsse:Password>
 </wsse:UsernameToken>
 </wsse:Security>
 </soapenv:Header>


当我点击该服务时,我收到以下错误消息。

[4/3/16 18:53:10:342 EET] 00000027 SystemErr     R javax.xml.ws.WebServiceException: org.apache.axis2.AxisFault: Must
> Understand check failed for header
> http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd
> : Security
>     [4/3/16 18:53:10:343 EET] 00000027 SystemErr     R    at org.apache.axis2.jaxws.ExceptionFactory.createWebServiceException(ExceptionFactory.java:175)
>     [4/3/16 18:53:10:343 EET] 00000027 SystemErr     R    at org.apache.axis2.jaxws.ExceptionFactory.makeWebServiceException(ExceptionFactory.java:70)
>     [4/3/16 18:53:10:343 EET] 00000027 SystemErr     R    at org.apache.axis2.jaxws.ExceptionFactory.makeWebServiceException(ExceptionFactory.java:128)
>     [4/3/16 18:53:10:343 EET] 00000027 SystemErr     R    at org.apache.axis2.jaxws.core.controller.impl.AxisInvocationController.execute(AxisInvocationController.java:586)
>     [4/3/16 18:53:10:343 EET] 00000027 SystemErr     R    at org.apache.axis2.jaxws.core.controller.impl.AxisInvocationController.doInvoke(AxisInvocationController.java:130)
>     [4/3/16 18:53:10:344 EET] 00000027 SystemErr     R    at org.apache.axis2.jaxws.core.controller.impl.InvocationControllerImpl.invoke(InvocationControllerImpl.java:93)
>     [4/3/16 18:53:10:344 EET] 00000027 SystemErr     R    at org.apache.axis2.jaxws.client.proxy.JAXWSProxyHandler.invokeSEIMethod(JAXWSProxyHandler.java:391)
>     [4/3/16 18:53:10:344 EET] 00000027 SystemErr     R    at org.apache.axis2.jaxws.client.proxy.JAXWSProxyHandler.invoke(JAXWSProxyHandler.java:208)
>     [4/3/16 18:53:10:344 EET] 00000027 SystemErr     R    at com.sun.proxy.$Proxy37.authenticateSP(Unknown Source)
>     [4/3/16 18:53:10:344 EET] 00000027 SystemErr     R    at com.id3global.id3gws._2013._04.IGlobalAuthenticate_BasicHttpBindingGlobalAuthenticate_Client.main(IGlobalAuthenticate_BasicHttpBindingGlobalAuthenticate_Client.java:90)
>     [4/3/16 18:53:10:345 EET] 00000027 SystemErr     R    at com.eeft.ws.ppd.EwalletBalanceInquiryWSBeanPortBindingImpl.ewalletBalanceInquiry(EwalletBalanceInquiryWSBeanPortBindingImpl.java:104)
>     [4/3/16 18:53:10:345 EET] 00000027 SystemErr     R    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
>     [4/3/16 18:53:10:345 EET] 00000027 SystemErr     R    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:60)
>     [4/3/16 18:53:10:345 EET] 00000027 SystemErr     R    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:37)
>     [4/3/16 18:53:10:345 EET] 00000027 SystemErr     R    at java.lang.reflect.Method.invoke(Method.java:611)
>     [4/3/16 18:53:10:345 EET] 00000027 SystemErr     R    at com.ibm.ws.webservices.engine.dispatchers.java.JavaDispatcher.invokeMethod(JavaDispatcher.java:203)
>     [4/3/16 18:53:10:346 EET] 00000027 SystemErr     R    at com.ibm.ws.webservices.engine.dispatchers.java.JavaDispatcher.invokeOperation(JavaDispatcher.java:158)
>     [4/3/16 18:53:10:346 EET] 00000027 SystemErr     R    at com.ibm.ws.webservices.engine.dispatchers.SoapRPCProcessor.processRequestResponse(SoapRPCProcessor.java:490)
>     [4/3/16 18:53:10:346 EET] 00000027 SystemErr     R    at com.ibm.ws.webservices.engine.dispatchers.SoapRPCProcessor.processMessage(SoapRPCProcessor.java:433)
>     [4/3/16 18:53:10:346 EET] 00000027 SystemErr     R    at com.ibm.ws.webservices.engine.dispatchers.BasicDispatcher.processMessage(BasicDispatcher.java:134)
>     [4/3/16 18:53:10:346 EET] 00000027 SystemErr     R    at com.ibm.ws.webservices.engine.dispatchers.java.SessionDispatcher.invoke(SessionDispatcher.java:204)
>     [4/3/16 18:53:10:346 EET] 00000027 SystemErr     R    at com.ibm.ws.webservices.engine.PivotHandlerWrapper.invoke(PivotHandlerWrapper.java:263)
>     [4/3/16 18:53:10:346 EET] 00000027 SystemErr     R    at com.ibm.ws.webservices.engine.handlers.jaxrpc.JAXRPCHandler.invoke(JAXRPCHandler.java:153)
>     [4/3/16 18:53:10:346 EET] 00000027 SystemErr     R    at com.ibm.ws.webservices.engine.handlers.WrappedHandler.invoke(WrappedHandler.java:64)
>     [4/3/16 18:53:10:347 EET] 00000027 SystemErr     R    at com.ibm.ws.webservices.engine.PivotHandlerWrapper.invoke(PivotHandlerWrapper.java:263)
>     [4/3/16 18:53:10:347 EET] 00000027 SystemErr     R    at com.ibm.ws.webservices.engine.PivotHandlerWrapper.invoke(PivotHandlerWrapper.java:263)
>     [4/3/16 18:53:10:347 EET] 00000027 SystemErr     R    at com.ibm.ws.webservices.engine.WebServicesEngine.invoke(WebServicesEngine.java:336)
>     [4/3/16 18:53:10:347 EET] 00000027 SystemErr     R    at com.ibm.ws.webservices.engine.transport.http.WebServicesServlet.doPost(WebServicesServlet.java:1246)
>     [4/3/16 18:53:10:347 EET] 00000027 SystemErr     R    at javax.servlet.http.HttpServlet.service(HttpServlet.java:738)
>     [4/3/16 18:53:10:347 EET] 00000027 SystemErr     R    at com.ibm.ws.webservices.engine.transport.http.WebServicesServletBase.service(WebServicesServletBase.java:344)
>     [4/3/16 18:53:10:347 EET] 00000027 SystemErr     R    at javax.servlet.http.HttpServlet.service(HttpServlet.java:831)
>     [4/3/16 18:53:10:347 EET] 00000027 SystemErr     R    at com.ibm.ws.webcontainer.servlet.ServletWrapper.service(ServletWrapper.java:1700)
>     [4/3/16 18:53:10:348 EET] 00000027 SystemErr     R    at com.ibm.ws.webcontainer.servlet.ServletWrapper.handleRequest(ServletWrapper.java:970)
>     [4/3/16 18:53:10:348 EET] 00000027 SystemErr     R    at com.ibm.ws.webcontainer.servlet.ServletWrapper.handleRequest(ServletWrapper.java:508)
>     [4/3/16 18:53:10:348 EET] 00000027 SystemErr     R    at com.ibm.ws.webcontainer.servlet.ServletWrapperImpl.handleRequest(ServletWrapperImpl.java:181)
>     [4/3/16 18:53:10:348 EET] 00000027 SystemErr     R    at com.ibm.ws.webcontainer.webapp.WebApp.handleRequest(WebApp.java:3994)
>     [4/3/16 18:53:10:348 EET] 00000027 SystemErr     R    at com.ibm.ws.webcontainer.webapp.WebGroup.handleRequest(WebGroup.java:276)
>     [4/3/16 18:53:10:348 EET] 00000027 SystemErr     R    at com.ibm.ws.webcontainer.WebContainer.handleRequest(WebContainer.java:945)
>     [4/3/16 18:53:10:348 EET] 00000027 SystemErr     R    at com.ibm.ws.webcontainer.WSWebContainer.handleRequest(WSWebContainer.java:1592)
>     [4/3/16 18:53:10:348 EET] 00000027 SystemErr     R    at com.ibm.ws.webcontainer.channel.WCChannelLink.ready(WCChannelLink.java:191)
>     [4/3/16 18:53:10:349 EET] 00000027 SystemErr     R    at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.handleDiscrimination(HttpInboundLink.java:454)
>     [4/3/16 18:53:10:349 EET] 00000027 SystemErr     R    at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.handleNewRequest(HttpInboundLink.java:516)
>     [4/3/16 18:53:10:349 EET] 00000027 SystemErr     R    at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.processRequest(HttpInboundLink.java:307)
>     [4/3/16 18:53:10:349 EET] 00000027 SystemErr     R    at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.ready(HttpInboundLink.java:278)
>     [4/3/16 18:53:10:349 EET] 00000027 SystemErr     R    at com.ibm.ws.tcp.channel.impl.NewConnectionInitialReadCallback.sendToDiscriminators(NewConnectionInitialReadCallback.java:214)
>     [4/3/16 18:53:10:349 EET] 00000027 SystemErr     R    at com.ibm.ws.tcp.channel.impl.NewConnectionInitialReadCallback.complete(NewConnectionInitialReadCallback.java:113)
>     [4/3/16 18:53:10:349 EET] 00000027 SystemErr     R    at com.ibm.ws.tcp.channel.impl.AioReadCompletionListener.futureCompleted(AioReadCompletionListener.java:175)
>     [4/3/16 18:53:10:349 EET] 00000027 SystemErr     R    at com.ibm.io.async.AbstractAsyncFuture.invokeCallback(AbstractAsyncFuture.java:217)
>     [4/3/16 18:53:10:349 EET] 00000027 SystemErr     R    at com.ibm.io.async.AsyncChannelFuture.fireCompletionActions(AsyncChannelFuture.java:161)
>     [4/3/16 18:53:10:350 EET] 00000027 SystemErr     R    at com.ibm.io.async.AsyncFuture.completed(AsyncFuture.java:138)
>     [4/3/16 18:53:10:350 EET] 00000027 SystemErr     R    at com.ibm.io.async.ResultHandler.complete(ResultHandler.java:204)
>     [4/3/16 18:53:10:350 EET] 00000027 SystemErr     R    at com.ibm.io.async.ResultHandler.runEventProcessingLoop(ResultHandler.java:775)
>     [4/3/16 18:53:10:350 EET] 00000027 SystemErr     R    at com.ibm.io.async.ResultHandler$2.run(ResultHandler.java:905)
>     [4/3/16 18:53:10:350 EET] 00000027 SystemErr     R    at com.ibm.ws.util.ThreadPool$Worker.run(ThreadPool.java:1662)
>     [4/3/16 18:53:10:350 EET] 00000027 SystemErr     R Caused by: org.apache.axis2.AxisFault: Must Understand check failed for header
> http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd
> : Security
>     [4/3/16 18:53:10:350 EET] 00000027 SystemErr     R    at org.apache.axis2.engine.AxisEngine.checkMustUnderstand(AxisEngine.java:127)
>     [4/3/16 18:53:10:351 EET] 00000027 SystemErr     R    at org.apache.axis2.engine.AxisEngine.receive(AxisEngine.java:191)
>     [4/3/16 18:53:10:351 EET] 00000027 SystemErr     R    at org.apache.axis2.description.OutInAxisOperationClient.handleResponse(OutInAxisOperation.java:363)
>     [4/3/16 18:53:10:351 EET] 00000027 SystemErr     R    at org.apache.axis2.description.OutInAxisOperationClient.send(OutInAxisOperation.java:416)
>     [4/3/16 18:53:10:351 EET] 00000027 SystemErr     R    at org.apache.axis2.description.OutInAxisOperationClient.executeImpl(OutInAxisOperation.java:228)
>     [4/3/16 18:53:10:351 EET] 00000027 SystemErr     R    at org.apache.axis2.client.OperationClient.execute(OperationClient.java:163)
>     [4/3/16 18:53:10:351 EET] 00000027 SystemErr     R    at org.apache.axis2.jaxws.core.controller.impl.AxisInvocationController.execute(AxisInvocationController.java:581)
>     [4/3/16 18:53:10:351 EET] 00000027 SystemErr     R    ... 50 more


我删除了mustunderstand标记,并将值更改为零仍然是相同的错误。

最佳答案

我错过了覆盖处理程序中的getHeaders()方法。下面的帖子帮助我添加了开始工作的处理程序。

SOAPFaultException "MustUnderstand headers (oasis-200401-wss-wssecurity-secext-1.0.xsd) are not understood"

@Override
    public Set<QName> getHeaders() {
        QName securityHeader = new QName("http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd",
                "Security");
        HashSet<QName> headers = new HashSet<QName>();
        headers.add(securityHeader);
        return headers;
    }

08-17 11:34