Web サービスのクライアントを作成しています。インターセプターを使用して 2 つのことを行いたいと考えています。1) 発信 XML メッセージをログに記録し、2) SOAP 応答ではなく HTTP 応答を読み取ります。
サービス側には 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 メッセージをログに記録しようとしました。そして、そこでも機能していません。助言がありますか?