Почему я получаю ошибку bad_certificate при использовании Spring и CXF - PullRequest
2 голосов
/ 20 октября 2010

Я использую сгенерированный CXF код для подключения к удаленному веб-сервису через SSL и через корпоративный прокси. Код работает нормально, когда соединение установлено через Java API и все настройки SSL установлены как системные свойства следующим образом.

System.setProperties("https.proxyHost", "myproxy.com");
System.setProperties("https.proxyPort", "8001");
System.setProperties("javax.net.ssl.keyStoreType", "pkcs12");
System.setProperties("javax.net.ssl.keyStore", "C:/keystore.p12");
System.setProperties("javax.net.ssl.keyStorePassword", "keypassword");
System.setProperties("javax.net.ssl.trustStore", "C:/cacerts");
System.setProperties("javax.net.ssl.trustStorePassword", "capassword");

MyWebService_Service ss = new MyWebService_Service(wsdlUrl, SERVICE_NAME);
MyWebService service = ss.getMyWebServicePort();

Используя этот код, я теперь могу вызывать методы сервиса, и все работает как положено. Мои проблемы возникают, когда я пытаюсь настроить ту же конфигурацию в Spring, что является нашим предпочтительным подходом, поскольку мы уже широко используем Spring.

Конфигурация My Spring:

<!-- relevant snippet from spring context -->

<import resource="classpath:META-INF/cxf/cxf.xml" />
<import resource="classpath:META-INF/cxf/cxf-extension-soap.xml" />
<import resource="classpath:META-INF/cxf/cxf-extension-http.xml" />

<jaxws:client id="webservice" serviceName="myns:MyWebService" endpointName="myns:MyWebServicePort"
     address="https://bigserver.com:5012/blah/TheWebService"
     serviceClass="com.mycomp.MyWebService" />

<http:conduit name="{myns}MyWebServicePort.http-conduit">
   <http:tlsClientParamenters disableCNCheck="true" secureSocketProtocol="TLS">
      <sec:trustManagers>
         <sec:keyStore type="JKS" password="capassword" file="c:/cacerts" />
      </sec:trustmanagers>
      <sec:keyManagers>
         <sec:keyStore type="pkcs12" password="keypassword" file="c:/keystore.p12" />
      </sec:keyManagers>
   </http:tlsClientParamenters>
   <http:client ProxyServer="myproxy.com" ProxyServerPort="8001" />
</http:conduit>

В обоих случаях клиент веб-службы развертывается в веб-приложении. Во втором случае доступ к веб-сервису приводит к

javax.net.ssl.SSLHandshakeException: Received fatal alert: bad_certificate

Редактировать: я использую CXF версии 2.2.

1 Ответ

0 голосов
/ 20 февраля 2014

Вы пытались добавить следующее свойство в параметры своего клиента?

**useHttpsURLConnectionDefaultHostnameVerifier="false"**

выглядит так:

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