CXF & SSL: проблемы с таймаутом - PullRequest
0 голосов
/ 30 апреля 2009

У меня есть следующий код, который я пытаюсь использовать для доступа к веб-сервису через HTTPS с использованием Apache CXF. Но всякий раз, когда мое сообщение выходит, я ничего не получаю, пока не истечет срок действия моего кода. Может кто-нибудь еще раз дать мой код и сообщить мне, если я делаю что-то не так. Я пытался получить доступ к сервису через SoapUI, и это нормально, поэтому в моем коде CXF должно быть что-то, но я просто не знаю, что!

Спасибо за любую помощь

DepositImplService ss = new DepositImplService(WSDL_LOCATION,
    SERVICE_NAME);
PortType port = ss.getPortTypePort();

Client client = ClientProxy.getClient(port);

HTTPConduit conduit = (HTTPConduit) client.getConduit();
HTTPClientPolicy httpClientPolicy = conduit.getClient();
httpClientPolicy.setConnectionTimeout(30000);
httpClientPolicy.setReceiveTimeout(30000);
conduit.setClient(httpClientPolicy);

AuthorizationPolicy authPolicy = new AuthorizationPolicy();
authPolicy.setUserName("foo");
authPolicy.setPassword("bar");
conduit.setAuthorization(authPolicy);

TLSClientParameters parameters = new TLSClientParameters();
parameters.setSecureSocketProtocol("SSL");
conduit.setTlsClientParameters(parameters);

client.getInInterceptors().add(new LoggingInInterceptor());
client.getOutInterceptors().add(new LoggingOutInterceptor());

UploadRequestT doc = new UploadRequestT();
BufferedReader reader = new BufferedReader(new FileReader(new File(
    "C:\\rawmessage.txt")));
String documentStr = "";
String currLine = "";
while ((currLine = reader.readLine()) != null) {
  documentStr += currLine;
}

doc.setDoc(documentStr);
doc.setOwner("43");
port.upload(doc);

1 Ответ

0 голосов
/ 30 апреля 2009

Каково время ответа от SoapUI?

Пропустили ли вы это через монитор, чтобы увидеть, что он отправляет в нужное место?

Мой код CXF выглядит так:

      PService phsService = new PService(url, SERVICE_NAME);
      P p = phsService.getPHSPort();
      LOG.info("Calling Web Service : getHs");

      StringArray ar = p.getHs();

      for (String hn: ar.getItem()) {
         LOG.info("Calling : getHName : " + hn);
         Dto nDto = p. getHName (hn);

         // process the result   

      }

Эта служба возвращает около 90 секунд и работает нормально

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...