Jax-ws: исключение Java SOAP: заголовки MustUnderstand: [{http://www.w3.org/2005/08/addressing}Действие

Я использую Jax-ws для реализации клиентского приложения для IP-камеры Onvif, я отправляю запрос на камеру для создания PullPointSubscription. Кажется, камера понимает запрос, обрабатывает запрос и отправляет правильный ответ, но клиентский код jax-ws выдает исключение

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>

person Mike Albren    schedule 29.01.2012    source источник
comment
Я боюсь, что пространство имен, на которое вы ссылаетесь (WS-Addressing 1.0) не поддерживается JAX-WS. Были ли какие-либо предупреждения от wsimport при создании артефактов JAX-WS?   -  person dma_k    schedule 30.01.2012
comment
У меня такая же проблема. Когда я запустил wsimport, появилось следующее предупреждение: неизвестный расширяемый элемент или атрибут EndpointReference (в пространстве имен w3.org/2005/08/addressing)   -  person Baumann    schedule 30.04.2016


Ответы (6)


У меня была такая же проблема с конкретным устройством, и мне потребовалось несколько дней поиска, проб и ошибок, чтобы найти решение (почти случайно). Я смог решить эту проблему, добавив в порт собственный обработчик. Обработчику нужно только предоставить 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);
person Steven Dillingham    schedule 02.10.2013

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

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

передавая new javax.xml.ws.soap.AddressingFeature() как WebServiceFeature .

person Majka    schedule 11.10.2016

Решение для ИСПРАВЛЕНИЯ

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

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

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

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

Итак, ИСПРАВЬТЕ кое-что в Кодексе:

Когда вы создаете экземпляр своей клиентской службы, вам нужно передать параметр «feature».

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».

person Caio Henrique    schedule 26.10.2016
comment
Добавление функций помогло. Спасибо! - person Christian Goudreau; 07.02.2019

да, я решил это

WSService service  = new WSService();
IWSService wcf = service.getWSHttpBindingIWSService(new AddressingFeature(true));
person lei king    schedule 08.03.2019

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

wsimport HelloWorld.wsdl -keep -d ./src/main/java -p com.trial.helloworld -XadditionalHeaders
person Aihal    schedule 20.02.2015

Если вы используете одну из аннотаций @WebService, @WebServiceProvider или @WebServiceRef, это можно решить, добавив также @Addressing аннотация из javax.xml.ws.soap.

person Stephan Berg    schedule 10.06.2021