Перехватчик CXF не вызывается для чтения ответа http

Я пишу клиент для веб-службы и хочу сделать две вещи с помощью перехватчика: 1) зарегистрировать исходящее XML-сообщение и 2) прочитать ответ HTTP, а не ответ SOAP.

На стороне службы есть только метод void, и они просто подтверждают получение моего сообщения через код ответа HTTP.

Вот как выглядит их ответ:

HTTP/1.1 202 Accepted
Date: Wed, 10 Jul 2013 23:06:36 GMT
Server: Oracle-Application-Server-11g
Content-Length: 0
X-ORACLE-DMS-ECID: 004sJ1KLm7yB_6RjMX^QsA0002X30001U5
X-Powered-By: Servlet/2.5 JSP/2.1
Content-Type: 
Content-Language: en
X-F5-ServerSSL-Profile: serverssl_sys_soaorexafun
X-F5-ForwardProxy-Host: 64.181.184.15%819 443

Мне нужен ответ "HTTP/1.1 202 Accepted".

Мой код перехватчика:

package com.cambiahealth.orservice.client;

import org.apache.cxf.binding.soap.interceptor.EndpointSelectionInterceptor;
import org.apache.cxf.binding.soap.interceptor.ReadHeadersInterceptor;
import org.apache.cxf.interceptor.Fault;
import org.apache.cxf.message.Message;
import org.apache.cxf.phase.AbstractPhaseInterceptor;
import org.apache.cxf.phase.Phase;
import org.apache.log4j.Logger;

public class CoverOregonServiceInterceptor extends AbstractPhaseInterceptor<Message> {

    static Logger logger = Logger.getLogger(CoverOregonServiceInterceptor.class.getName());
    private static Integer responseCode = 0;

    public CoverOregonServiceInterceptor() {
        super(Phase.POST_INVOKE);
        addAfter(ReadHeadersInterceptor.class.getName());
        addAfter(EndpointSelectionInterceptor.class.getName());
    }

    @Override
    public void handleMessage(Message message) throws Fault {
        try{
            responseCode = (Integer) message.get(Message.RESPONSE_CODE);
            logger.info("Response Code is " + responseCode);
        } catch (Exception e){
            logger.error("Failed to read the response code from Soap message", e);
        }        
    }

    public Integer getResponseCode(){
        return responseCode;
    }

}

И код в моем клиенте:

String wsdlUrl = coverOregonServiceUrl + "?wsdl";
CoverOregonServiceInterceptor interceptor = new CoverOregonServiceInterceptor();
CoverOregonServiceInterceptor outInterceptor = new CoverOregonServiceInterceptor();
InboundEnrollmentManagementClient client = new InboundEnrollmentManagementClient(
                    new URL(wsdlUrl));
InboundEnrollManagementPortType port = client.getInboundEnrollManagementPort();
Client cxfClient = ClientProxy.getClient(port);
cxfClient.getInInterceptors().add(interceptor); 
cxfClient.getOutFaultInterceptors().add(outInterceptor);
port.statusupdate(request);

Однако мой перехватчик вообще не вызывается/не срабатывает. Я пробовал разные фазы - READ, RECEIVE, PRE_INVOKE, POST_INVOKE, INVOKE, POST_STREAM, SEND. Но ни один из них не работал. Я попробовал аналогичный перехватчик для регистрации XML-сообщения перед отправкой запроса. И там тоже не работает. Какие-либо предложения?


person Rishi P    schedule 15.07.2013    source источник
comment
Вы пробовали с PRE_STREAM (как это делает org.apache.cxf.interceptor.LoggingOutInterceptor)   -  person willome    schedule 16.07.2013
comment
PRE_STREAM работал с перехватчиком ведения журнала, чтобы получить XML-сообщение. Спасибо.   -  person Rishi P    schedule 16.07.2013


Ответы (1)


Догадаться. Служба, которую я вызываю, не имеет возврата, поэтому я не могу использовать входящую цепочку перехватчиков.

cxfClient.getInInterceptors().add(interceptor);

Я использовал его в исходящей цепочке, и это сработало.

cxfClient.getOutInterceptors().add(outInterceptor);
person Rishi P    schedule 16.07.2013