Подтвердить что ты не робот

Ошибка при доступе к веб-службе с помощью SSL

У меня есть программа, которая должна отправить файл в веб-службу, для которой требуется SSL-соединение. Я запускаю программу следующим образом:

SET JAVA_HOME=C:\Program Files\Java\jre1.6.0_07
SET com.ibm.SSL.ConfigURL=ssl.client.props
"%JAVA_HOME%\bin\java" -cp ".;Test.jar" ca.mypackage.Main

Это прекрасно работает, но когда я меняю первую строку на

SET JAVA_HOME=C:\Program Files\IBM\SDP\runtimes\base_v7\java\jre

Я получаю следующую ошибку:

com.sun.xml.internal.ws.client.ClientTransportException: HTTP transport error: java.net.SocketException: java.lang.ClassNotFoundException: Cannot find the specified class com.ibm.websphere.ssl.protocol.SSLSocketFactory
at com.sun.xml.internal.ws.transport.http.client.HttpClientTransport.getOutput(HttpClientTransport.java:119)
at com.sun.xml.internal.ws.transport.http.client.HttpTransportPipe.process(HttpTransportPipe.java:140)
at com.sun.xml.internal.ws.transport.http.client.HttpTransportPipe.processRequest(HttpTransportPipe.java:86)
at com.sun.xml.internal.ws.api.pipe.Fiber.__doRun(Fiber.java:593)
at com.sun.xml.internal.ws.api.pipe.Fiber._doRun(Fiber.java:552)
at com.sun.xml.internal.ws.api.pipe.Fiber.doRun(Fiber.java:537)
at com.sun.xml.internal.ws.api.pipe.Fiber.runSync(Fiber.java:434)
at com.sun.xml.internal.ws.client.Stub.process(Stub.java:247)
at com.sun.xml.internal.ws.client.sei.SEIStub.doProcess(SEIStub.java:132)
at com.sun.xml.internal.ws.client.sei.SyncMethodHandler.invoke(SyncMethodHandler.java:242)
at com.sun.xml.internal.ws.client.sei.SyncMethodHandler.invoke(SyncMethodHandler.java:222)
at com.sun.xml.internal.ws.client.sei.SEIStub.invoke(SEIStub.java:115)
at $Proxy26.fileSubmit(Unknown Source)
at com.testing.TestingSoapProxy.fileSubmit(TestingSoapProxy.java:81)
at ca.mypackage.Main.main(Main.java:63)
Caused by: java.net.SocketException: java.lang.ClassNotFoundException: Cannot find the specified class com.ibm.websphere.ssl.protocol.SSLSocketFactory
at javax.net.ssl.DefaultSSLSocketFactory.a(SSLSocketFactory.java:7)
at javax.net.ssl.DefaultSSLSocketFactory.createSocket(SSLSocketFactory.java:1)
at com.ibm.net.ssl.www2.protocol.https.c.afterConnect(c.java:110)
at com.ibm.net.ssl.www2.protocol.https.d.connect(d.java:14)
at sun.net.www.protocol.http.HttpURLConnection.getOutputStream(HttpURLConnection.java:902)
at com.ibm.net.ssl.www2.protocol.https.b.getOutputStream(b.java:86)
at com.sun.xml.internal.ws.transport.http.client.HttpClientTransport.getOutput(HttpClientTransport.java:107)
... 14 more
Caused by: java.lang.ClassNotFoundException: Cannot find the specified class com.ibm.websphere.ssl.protocol.SSLSocketFactory
at javax.net.ssl.SSLJsseUtil.b(SSLJsseUtil.java:20)
at javax.net.ssl.SSLSocketFactory.getDefault(SSLSocketFactory.java:36)
at javax.net.ssl.HttpsURLConnection.getDefaultSSLSocketFactory(HttpsURLConnection.java:16)
at javax.net.ssl.HttpsURLConnection.<init>(HttpsURLConnection.java:36)
at com.ibm.net.ssl.www2.protocol.https.b.<init>(b.java:1)
at com.ibm.net.ssl.www2.protocol.https.Handler.openConnection(Handler.java:11)
at java.net.URL.openConnection(URL.java:995)
at com.sun.xml.internal.ws.api.EndpointAddress.openConnection(EndpointAddress.java:206)
at com.sun.xml.internal.ws.transport.http.client.HttpClientTransport.createHttpConnection(HttpClientTransport.java:277)
at com.sun.xml.internal.ws.transport.http.client.HttpClientTransport.getOutput(HttpClientTransport.java:103)
... 14 more

Таким образом, похоже, что эта проблема будет связана с JRE, которую я использую, но, похоже, не имеет смысла, так это то, что JRE от IBM не работает отлично, но IBM JRE этого не делает. Любые идеи или предложения?

4b9b3361

Ответ 1

Если ваш не IBM jre - это солнце, тогда он уже поставляется с реализацией классов SSL вместе с ним.

Кажется, что IBM jre не содержит классов реализации SSL вообще.

Ответ 2

Попробуйте добавить эти две строки где-нибудь в вашем установочном коде:

Security.setProperty("ssl.SocketFactory.provider", "com.ibm.jsse2.SSLSocketFactoryImpl");
Security.setProperty("ssl.ServerSocketFactory.provider", "com.ibm.jsse2.SSLServerSocketFactoryImpl");

Ответ 3

Java разрешает только один SSL-соединение factory для JVM. Если вы используете JDK, который поставляется с WebSphere Application Server v6x/7x/8x или любыми другими серверными инструментами WebSphere в Rational Application Developer, для этого требуется специальный класс IBM (com.ibm.websphere.ssl.protocol.SSLSocketFactory) из приложения WebSphere Application Время выполнения сервера. потому что в файле безопасности java есть фабрики сокетов JSSE, установленные ниже

# Default JSSE socket factories
#ssl.SocketFactory.provider=com.ibm.jsse2.SSLSocketFactoryImpl
#ssl.ServerSocketFactory.provider=com.ibm.jsse2.SSLServerSocketFactoryImpl

# WebSphere socket factories (in cryptosf.jar)
ssl.SocketFactory.provider=com.ibm.websphere.ssl.protocol.SSLSocketFactory
ssl.ServerSocketFactory.provider=com.ibm.websphere.ssl.protocol.SSLServerSocketFactory

Итак, если вы раскомментируете фабрики JSSE Socket по умолчанию и закомментируете WebSphere, то WAS будет запугиваться.

Лучше работать с файлом com.ibm.ws.security.crypto.jar в вашем пути к классу. Этот файл jar имеет зависимость от файла com.ibm.ffdc.jar, поэтому вам нужно, чтобы в вашем пути класса хорошо. Оба этих jarfiles доступны под <WebSphere_Install_Dirctory>/plugins/

Ответ 4

можно установить эти свойства в файле WAS_HOME/*/java/jre/lib/security/java.security, не подвергая сомнению следующие реквизиты JSSE.

По умолчанию фабрики сокетов JSSE

ssl.SocketFactory.provider = com.ibm.jsse2.SSLSocketFactoryImpl ssl.ServerSocketFactory.provider = com.ibm.jsse2.SSLServerSocketFactoryImpl

Ответ 5

Еще одно "решение", которое, похоже, работает на меня. Создайте свой собственный файл свойств безопасности my.java.security с содержимым, например:

ssl.SocketFactory.provider=
ssl.ServerSocketFactory.provider=

При вызове Java (или в моем случае maven) добавьте параметр командной строки:

-Djava.security.properties=C:\myfiles\my.java.security

Cribbed из документации IBM Liberty: http://www-01.ibm.com/support/knowledgecenter/was_beta_liberty/com.ibm.websphere.wlp.nd.multiplatform.doc/ae/rwlp_trouble.html?lang=en

Ответ 6

Нашел этот раздел при поиске того же сообщения об ошибке, но нашел другое решение. Чтобы проверить службу https REST с помощью клиента Apache Wink:

ClientConfig config = new ClientConfig();
config.setBypassHostnameVerification(true);
RestClient client = new RestClient(config);

И установите Factory empty:

Security.setProperty("ssl.SocketFactory.provider", "");
Security.setProperty("ssl.ServerSocketFactory.provider", "");

Моя среда исполнения - это автономный тест Camel с использованием IBM JRE 1.7 от IBM WebSphere v8.5.5.

Ответ 7

У меня была аналогичная проблема, когда мое пакетное приложение пыталось извлечь данные из Restful web-сервиса с помощью Apache. Я использовал MyEclipse в качестве среды моего dev. И использовал jre, предоставленный IBM webSphere 8.5. Когда я перешел на Sun 1.6 jre, проблема была решена.