2012-01-29 1 views
4

Я использую Jax-ws для реализации клиентского приложения для IP-камеры Onvif, я отправив запрос на камеру для создания PullPointSubscription, кажется камера понимает запрос и обработать запрос и отправить правильный ответ, но код клиента JAX-WS генерирует исключениеJax-ws: исключение Java SOAP: заголовки MustUnderstand: [{http://www.w3.org/2005/08/addressing} Действие

MustUnderstand headers:[{http://www.w3.org/2005/08/addressing}Action] are not understood 

Я не понимаю, что такое проблема точно? Кто-нибудь может объяснить, в чем проблема и как ее решить?

Детали исключения

an 29, 2012 11:43:48 AM com.sun.xml.ws.protocol.soap.MUTube getMisUnderstoodHeaders 
INFO: Element not understood={http://www.w3.org/2005/08/addressing}Action 
javax.xml.ws.soap.SOAPFaultException: MustUnderstand headers:[{http://www.w3.org/2005/08/addressing}Action] are not understood 
    at com.sun.xml.ws.protocol.soap.MUTube.createMUSOAPFaultException(MUTube.java:148) 
    at com.sun.xml.ws.protocol.soap.ClientMUTube.processResponse(ClientMUTube.java:109) 
    at com.sun.xml.ws.api.pipe.Fiber.__doRun(Fiber.java:651) 
    at com.sun.xml.ws.api.pipe.Fiber._doRun(Fiber.java:600) 
    at com.sun.xml.ws.api.pipe.Fiber.doRun(Fiber.java:585) 
    at com.sun.xml.ws.api.pipe.Fiber.runSync(Fiber.java:482) 
    at com.sun.xml.ws.client.Stub.process(Stub.java:323) 
    at com.sun.xml.ws.client.sei.SEIStub.doProcess(SEIStub.java:161) 
    at com.sun.xml.ws.client.sei.SyncMethodHandler.invoke(SyncMethodHandler.java:113) 
    at com.sun.xml.ws.client.sei.SyncMethodHandler.invoke(SyncMethodHandler.java:93) 
    at com.sun.xml.ws.client.sei.SEIStub.invoke(SEIStub.java:144) 
    at $Proxy46.createPullPointSubscription(Unknown Source) 
    at Test.SubInEventLast(Test.java:173) 
    at Test.main(Test.java:139) 

Сообщение запроса мыло

<?xml version='1.0' encoding='UTF-8'?> 
<S:Envelope xmlns:S="http://www.w3.org/2003/05/soap-envelope"> 
    <S:Body> 
    <ns6:CreatePullPointSubscription xmlns:ns2="http://www.w3.org/2005/08/addressing" 
     xmlns:ns3="http://docs.oasis-open.org/wsn/b-2" 
     xmlns:ns4="http://docs.oasis-open.org/wsrf/bf-2" 
     xmlns:ns5="http://docs.oasis-open.org/wsn/t-1" 
     xmlns:ns6="http://www.onvif.org/ver10/events/wsdl" 
     xmlns:ns7="http://www.onvif.org/ver10/schema" 
     xmlns:xmime="http://www.w3.org/2005/05/xmlmime" 
     xmlns:ns9="http://www.w3.org/2004/08/xop/include" 
     xmlns:ns10="http://docs.oasis-open.org/wsrf/r-2"> 
     <ns6:Filter> 
      <ns3:TopicExpression xmlns="http://docs.oasis-open.org/wsn/b-2" 
       xmlns:tns1="http://www.onvif.org/ver10/topics" 
       Dialect="http://www.onvif.org/ver10/tev/topicExpression/ConcreteSet"> 
       tns1:Device 
      </ns3:TopicExpression> 
     </ns6:Filter> 
     <ns3:InitialTerminationTime>PT1M</ns3:InitialTerminationTime> 
    </ns6:CreatePullPointSubscription> 
    </S:Body> 
</S:Envelope> 

и это ответ мыло

   <?xml version="1.0" encoding="UTF-8"?> 
       <SOAP-ENV:Envelope xmlns:SOAP-ENV="http://www.w3.org/2003/05/soap-envelope" 
        xmlns:SOAP-ENC="http://www.w3.org/2003/05/soap-encoding" 
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
        xmlns:xsd="http://www.w3.org/2001/XMLSchema" 
        xmlns:c14n="http://www.w3.org/2001/10/xml-exc-c14n#" 
        xmlns:wsu="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd" 
        xmlns:ds="http://www.w3.org/2000/09/xmldsig#" xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd" 
        xmlns:wsa5="http://www.w3.org/2005/08/addressing" 
        xmlns:xmime5="http://www.w3.org/2005/05/xmlmime" 
        xmlns:wsrf-bf="http://docs.oasis-open.org/wsrf/bf-2" 
        xmlns:wstop="http://docs.oasis-open.org/wsn/t-1" 
        xmlns:tt="http://www.onvif.org/ver10/schema" 
        xmlns:wsrf-r="http://docs.oasis-open.org/wsrf/r-2" 
        xmlns:tan1="http://www.onvif.org/ver10/analytics/wsdl/RuleEngineBinding" 
        xmlns:tan="http://www.onvif.org/ver10/analytics/wsdl" 
        xmlns:tan2="http://www.onvif.org/ver10/analytics/wsdl/AnalyticsEngineBinding" 
        xmlns:tds="http://www.onvif.org/ver10/device/wsdl" 
        xmlns:tev1="http://www.onvif.org/ver10/events/wsdl/NotificationProducerBinding" 
        xmlns:tev2="http://www.onvif.org/ver10/events/wsdl/EventBinding" 
        xmlns:tev3="http://www.onvif.org/ver10/events/wsdl/SubscriptionManagerBinding" 
        xmlns:wsnt="http://docs.oasis-open.org/wsn/b-2" 
        xmlns:tev4="http://www.onvif.org/ver10/events/wsdl/PullPointSubscriptionBinding" 
        xmlns:tev="http://www.onvif.org/ver10/events/wsdl" 
        xmlns:timg="http://www.onvif.org/ver10/imaging/wsdl" 
        xmlns:tptz="http://www.onvif.org/ver10/ptz/wsdl" 
        xmlns:trt="http://www.onvif.org/ver10/media/wsdl" 
        xmlns:ter="http://www.onvif.org/ver10/error" 
        xmlns:tns1="http://www.onvif.org/ver10/topics" 
        xmlns:tnsaxis="http://www.axis.com/2009/event/topics"> 
        <SOAP-ENV:Header> 
         <wsa5:Action SOAP-ENV:mustUnderstand="true">http://docs.oasis-open.org/wsn/bw-2/SubscriptionManager/CreatePullPointSubscriptionResponse</wsa5:Action> 
        </SOAP-ENV:Header> 
        <SOAP-ENV:Body> 
         <tev:CreatePullPointSubscriptionResponse> 
          <tev:SubscriptionReference> 
          <wsa5:Address>http://192.168.0.151/onvif/services</wsa5:Address> 
          <wsa5:ReferenceParameters><dom0:SubscriptionId xmlns:dom0="http://www.axis.com/2009/event">3</dom0:SubscriptionId> 
          </wsa5:ReferenceParameters> 
         </tev:SubscriptionReference> 
         <wsnt:CurrentTime>2010-10-27T09:11:42Z</wsnt:CurrentTime> 
         <wsnt:TerminationTime>2010-11-24T09:11:42Z</wsnt:TerminationTime></tev:CreatePullPointSubscriptionResponse> 
        </SOAP-ENV:Body> 
       </SOAP-ENV:Envelope> 
+0

Я боюсь, что пространство имен, на которое вы ссылаетесь ([WS-Addressing 1.0] (http://www.w3.org/TR/2006/REC-ws-addr-soap-20060509/)) не поддерживается JAX-WS. Были ли какие-либо предупреждения 'wsimport', когда вы создали артефакты JAX-WS? –

+0

У меня такая же проблема. Когда я запустил 'wsimport', было показано следующее предупреждение: _unknown элемент расширяемости или атрибут« EndpointReference »(в пространстве имен« http://www.w3.org/2005/08/addressing")_ – Baumann

ответ

6

У меня была такая же проблема с конкретным устройством и этим взял меня на несколько дней поиска и испытания и ошибки, чтобы придумать решение (почти чисто с помощью c Hance). Я смог решить эту проблему, добавив пользовательский обработчик в порт. Обработчик должен только предоставить QName для заголовка действия WS-Addressing (ему не нужно ничего делать, когда вызывается handleMessage).

Это то, что работает для меня:

public class ActionHandler implements SOAPHandler<SOAPMessageContext> 
{ 
    @Override 
    public boolean handleMessage(SOAPMessageContext context) 
    { 
     // Auto-generated method stub 
     return true; 
    } 

    @Override 
    public boolean handleFault(SOAPMessageContext context) 
    { 
     // Auto-generated method stub 
     return false; 
    } 

    @Override 
    public void close(MessageContext context) 
    { 
     // Auto-generated method stub 
    } 

    @Override 
    public Set<QName> getHeaders() 
    { 
     Set<QName> set = new HashSet<QName>(); 
     // Make sure the '[{http://www.w3.org/2005/08/addressing}]Action' header 
     // is handled in case the device set the 'MustUnderstand' attribute to '1' 
     set.add(new QName("http://www.w3.org/2005/08/addressing", "Action")); 
     return set; 
    } 
} 

Затем добавьте обработчик для связывания обработчиков цепи:

BindingProvider bindingProvider = (BindingProvider) eventPortType;  
final Binding binding = bindingProvider.getBinding(); 

List<Handler> handlerList = binding.getHandlerChain(); 
if (handlerList == null) 
    handlerList = new ArrayList<Handler>(); 

handlerList.add(new ActionHandler()); 

binding.setHandlerChain(handlerList); 
0

Другой способ решения этой проблемы является добавление «-XadditionalHeaders» аргумент к команда wsimport. Это добавит параметры заголовка запроса/ответа к методу службы.

wsimport HelloWorld.wsdl -keep -d ./src/main/java -p com.trial.helloworld -XadditionalHeaders 
3

В моем случае, это помогает:

getPort(QName portName, 
      Class<T> serviceEndpointInterface, WebServiceFeature... features) 

проходя new javax.xml.ws.soap.AddressingFeature() в WebServiceFeature.

3

Решение FIX

  • "MustUnderstand заголовки: [{http://www.w3.org/2005/08/addressing} Действие] не понял"

  • "Сервер послал HTTP-код состояния 415: Невозможно обработать сообщение, потому что тип контента 'application/soap + xml; charset = "utf-8"; "

Использование NetBeans версии 7.1 или выше для создания клиента веб-службы.

(NetBeans будет использовать javax.xml.ws.Сервис)

Так FIX некоторые вещи в кодексе:

При создании экземпляра вашей службы клиента, вам нужно пройти «функцию» параметров.

com.sun.xml.internal.ws.developer.BindingTypeFeature featureB = new BindingTypeFeature(javax.xml.ws.soap.SOAPBinding.SOAP12HTTP_BINDING); 
javax.xml.ws.soap.AddressingFeature featureA = new AddressingFeature(); 

IGeneratedServiceEV servico = new GeneratedService() 
.getBasicHttpBindingGeneratedServiceEV(featureA,featureB); 

Самое главное, что вы должны создать службу, используя "особенность": "javax.xml.ws.Service.getPort (wsdlLocation, featureA, FeatureB)"

После того, как вы можете перенести код на другую среду IDE, например «Eclipse».