Сбой JAX-RPC GenericHandler на сервере приложений Websphere v6.0.2.35

StackOverflow https://stackoverflow.com/questions/1806412

  •  05-07-2019
  •  | 
  •  

Вопрос

Я создал расширение GenericHandler под названием SOAPHeaderHandler. Я поместил операторы log4j в обработчик и вижу, как строится конструктор. Однако, когда я генерирую сообщение SOAP, я не вижу сообщения, связанного с методом handleRequest. Я зарегистрировал обработчик в заглушке следующим образом:

if (service == null) {
    super.service = new com.ibm.ws.webservices.engine.client.Service();
}
else {
    super.service = service;
}
List handlerInfoList = new ArrayList();
QName[] headersArr = null;
HandlerInfo handlerInfo = new HandlerInfo(com.xxxxxx.hdhp.business.debitcard.cardservices.CardServiceSOAPHeaderHandler.class, 
     null, headersArr);
handlerInfoList.add(handlerInfo);
service.getHandlerRegistry().setHandlerChain(new QName("MetavanteDebitCard"), handlerInfoList);

Обработчик:

public class AccountManagementSOAPHeaderHandler extends GenericHandler {
 private static Logger logger = Logger.getLogger  (AccountManagementSOAPHeaderHandler.class);
 private HandlerInfo handlerInfo = null;

public AccountManagementSOAPHeaderHandler () {
 logger.info("Constructing AccountManagementSOAPHeaderHandler");
}

 /* (non-Javadoc)
  * @see javax.xml.rpc.handler.GenericHandler#getHeaders()
  */
 public QName[] getHeaders() {
 logger.info("calling getHeaders()");
  return null;
 }

 public boolean handleFault(MessageContext arg0) {
     logger.info("Fault in AccountManagementSOAPHeaderHandler");
  return true;
 }
 public boolean handleResponse(MessageContext arg0) {
   logger.info("Response in AccountManagementSOAPHeaderHandler");
   return true;
 }
 public void init(HandlerInfo arg0) {
  logger.info("init in AccountManagementSOAPHeaderHandler");
  handlerInfo = arg0;
  super.init(arg0);
 }

 public void destroy() {
  logger.info("--- In AccountManagementSOAPHeaderHandler.destroy ()");
 } 

 public boolean handleRequest(MessageContext ctx) {
     logger.debug("BEGIN handleRequest()");
     if (ctx instanceof SOAPMessageContext) {
        SOAPMessageContext context = (SOAPMessageContext) ctx;
        logger.debug("instance of SOAPMessageContext");
        try {
           SOAPHeader header = context.getMessage().getSOAPPart()
                .getEnvelope().getHeader();
           logger.debug("SOAP Header is " + ((header==null)?"NULL":"NOT NULL"));
           Iterator headers = header
                .extractHeaderElements("http://schemas.xmlsoap.org/soap/actor/next");
           while (headers.hasNext()) {
               SOAPHeaderElement he = (SOAPHeaderElement) headers.next();
               logger.info("HEADER Qn " + he.getElementName().getQualifiedName());
           }
       } catch (SOAPException x) {
           logger.error("SOAPException while handlingRequest for SOAP: '" + x.getMessage() + "'");
   }
  }
 return true;
}

и я изменил web.xml следующим образом:

   <service-ref>
        <description>WSDL Service AccountManagerService</description>
        <service-ref-name>service/AccountManagerService</service-ref-name>
        <service-interface>com.medibank.www.AccountManagerService</service-interface>
<!--        <wsdl-file>WEB-INF/wsdl/AccountManagerService.asmx.wsdl</wsdl-file>-->
        <jaxrpc-mapping-file>WEB-INF/AccountManagerService.asmx_mapping.xml</jaxrpc-mapping-file>
        <service-qname xmlns:pfx="http://www.medibank.com/MBIWebServices/Access/Services/AccountManager/2004/06/">pfx:AccountManagerService</service-qname>
        <port-component-ref>
            <service-endpoint-interface>com.medibank.www.AccountManagerServiceSoap</service-endpoint-interface>
        </port-component-ref>
        <port-component-ref>
            <service-endpoint-interface>com.medibank.www.AccountManagerServiceSoap</service-endpoint-interface>
        </port-component-ref>
        <handler>
         <description>
         </description>
         <display-name></display-name>
         <handler-name>AccountManagementSOAPHeaderHandler</handler-name>
         <handler-class>com.xxxxx.hdhp.business.debitcard.accountmanagement.AccountManagementSOAPHeaderHandler</handler-class>
        </handler>
    </service-ref>

Он развернут на сервере приложений Websphere v6.0.2.35. Есть идеи, в чем может быть проблема? Почему операторы регистратора в обработчике никогда не выполняются? Не удалось ли правильно зарегистрировать обработчик? Нужно ли указывать, какие методы обслуживания обрабатываются?

Это было полезно?

Решение

Я написал несколько клиентов JAX-RPC SOAP, которые работают на WAS 6.0, и требуют, чтобы GenericHandlers добавляли настраиваемый заголовок SOAP для запроса сообщений. У меня также было требование не использовать service-ref (по соображениям простоты использования в клиентской кодовой базе), поэтому мой клиентский класс устанавливает обработчик программным способом. Это может не совсем соответствовать тому, как работает ваша конфигурация, но, возможно, что-то пригодится.

Я начал с клиентского кода, сгенерированного инструментом Ant RAD 7.5 WSDL2Java в Ant, но " Web Service Client " Волшебник использует это также. Он создал все бизнес-объекты, сериализатор / десериализаторы, классы связывания локатора и SOAP и т. Д. И т. Д. Затем я создал пользовательский GenericHandler, аналогичный тому, который у вас есть.

Поскольку у меня не было сервисной ссылки, я не мог привязать ее к клиенту таким образом. Поэтому я использовал следующий код в самом клиентском классе, чтобы программно добавить обработчик:

private AccountManager createAccountManagerStub() throws Exception {
    AccountManagerServiceLocator locator = new AccountManagerServiceLocator();

    // Set the JMS endpoint address
    AccountManagerSOAPBindingStub accountManagerStub = (AccountManagerSOAPBindingStub) locator
            .getAccountManagerSOAPPort(new URL(generateJMSEndpointAddress()));

    // Set the Client Handler
    HandlerRegistry registry = locator.getHandlerRegistry();
    List chain = registry
            .getHandlerChain((QName) locator.getPorts().next());
    HandlerInfo handlerInfo = new HandlerInfo();
    handlerInfo.setHandlerClass(AccountManagerClientHandler.class);
    chain.add(handlerInfo);

    return (AccountManager) accountManagerStub;
}

Объект, возвращаемый этим методом, полностью настроен, и вызов любого из клиентских методов этого класса работает правильно. Метод AccountManagerClientHandler.handleRequest (MessageContext msgContext) вызывается, messageContext обновляется, а затем сообщение отправляется в веселом режиме.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top