私はEJBステートレスBeanWebサービスを使用しており、現在パラメーターを取得しているSOAP本文だけでなく、SOAPメッセージ全体にアクセスしたいと考えています。別のコンポーネントにメッセージを送信したい。Spring構成を使用していますが、Spring-WSは使用していません。私はこのチュートリアルに従いました:
http://java.dzone.com/articles/creating-soap-message-handlers
現状のままで、今のところ変更はありません。SOAPメッセージをログに記録するだけです。handleMessage()が呼び出されていません。
@Stateless
@WebService(portName = "XRequest_PortType", serviceName = "XRequestService", endpointInterface = "XRequestPortType")
@Addressing(enabled = true)
@HandlerChain(file = "LogMessage_handler.xml")
@Interceptors(SpringBeanAutowiringInterceptor.class)
public class XRequest_PortTypeWS implements
XRequestPortType {
...}
LogMessage_handler.xmlはチュートリアルとは少し異なりますが、両方の方法で試しました。
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<javaee:handler-chains
xmlns:javaee="http://java.sun.com/xml/ns/javaee"
xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<javaee:handler-chain>
<javaee:handler>
<javaee:handler-class>com.test.ws.LogMessageHandle</javaee:handler-class>
</javaee:handler>
</javaee:handler-chain>
</javaee:handler-chains>
LogMessageHandler:
package com.test.ws;
import java.io.IOException;
import java.util.Collections;
import java.util.Set;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.xml.namespace.QName;
import javax.xml.soap.SOAPException;
import javax.xml.soap.SOAPMessage;
import javax.xml.ws.handler.MessageContext;
import javax.xml.ws.handler.soap.SOAPHandler;
import javax.xml.ws.handler.soap.SOAPMessageContext;
/**
*
* @author meerasubbarao
*/
public class LogMessageHandler implements SOAPHandler<SOAPMessageContext> {
public boolean handleMessage(SOAPMessageContext messageContext) {
log(messageContext);
return true;
}
public Set<QName> getHeaders() {
return Collections.EMPTY_SET;
}
public boolean handleFault(SOAPMessageContext messageContext) {
return true;
}
public void close(MessageContext context) {
}
private void log(SOAPMessageContext messageContext) {
SOAPMessage msg = messageContext.getMessage(); // Line 1
try {
msg.writeTo(System.out); // Line 3
} catch (SOAPException ex) {
Logger.getLogger(LogMessageHandler.class.getName()).log(
Level.SEVERE, null, ex);
} catch (IOException ex) {
Logger.getLogger(LogMessageHandler.class.getName()).log(
Level.SEVERE, null, ex);
}
}
}
これは、SOAPメッセージ全体を取得するための最良の方法でさえありますか?それでも、SOAPメッセージを送信するには、XRequest_PortTypeWSからSpringBeanを呼び出す必要があります。