2016-07-13 1 views
2

У меня есть следующий код для подключения к серверу веб-сокетов в моем приложении Java с помощью защищенных веб-узлов.Продолжайте получать доступную версию X509TrustManager при попытке подключения к серверу веб-сокетов

private boolean openConnection(boolean tried) { 
    String sslFile = 
     ConfigMgr.getValue(Constants.SSL_CFG_NAME, "sslfile"); 
    String sslPassword = 
     ConfigMgr.getValue(Constants.SSL_CFG_NAME, "sslpassword"); 
    try { 
     System.setProperty("javax.net.ssl.trustStore", 
       //sslFile); 
     System.setProperty("javax.net.ssl.trustStorePassword", sslPassword); 
     System.out.println(System.getProperty("javax.net.ssl.trustStore")); 
     System.out.println(System.getProperty("javax.net.ssl.trustStorePassword")); 
    } catch (Exception e) { 
     if (!tried) { 
      logger.error("unable to get certificates", e); 
     } 
     return false; 
    } 
    try { 
     WebSocketContainer container = ContainerProvider 
       .getWebSocketContainer(); 
     container.connectToServer(this, new URI(websocketServer)); 
    } catch (Exception e) { 
     // only log error trying to connection to web application first 
     // time 
     if (!tried) { 
      logger.error("error while trying to connect daemon to websocket" 
        + " server", e); 
     } 
     return false; 
    } 
    return true; 
} 

Я могу видеть из моих заявлений печати

System.setProperty("javax.net.ssl.trustStorePassword", sslPassword); 

и

System.out.println(System.getProperty("javax.net.ssl.trustStore")); 

Это правильный пароль и сертификат (а .cer в данном случае) с содержанием

-----BEGIN CERTIFICATE----- 
MIIDmTCCAoGgAwIBAgIEB/pKmDANBgkqhkiG9w0BAQsFADB9MQswCQYDVQQGEwJV 
UzELMAkGA1UECBMCUEExGDAWBgNVBAcTD0ZvcnQgV2FzaGluZ3RvbjEXMBUGA1UE 
ChMOTWlrcm9zIFN5c3RlbXMxFzAVBgNVBAsTDk1pa3JvcyBTeXN0ZW1zMRUwEwYD 
VQQDEwxKYXNvbiBSaWNsZXMwHhcNMTYwNjIyMTcwOTQ0WhcNMTYwOTIwMTcwOTQ0 
WjB9MQswCQYDVQQGEwJVUzELMAkGA1UECBMCUEExGDAWBgNVBAcTD0ZvcnQgV2Fz 
aGluZ3RvbjEXMBUGA1UEChMOTWlrcm9zIFN5c3RlbXMxFzAVBgNVBAsTDk1pa3Jv 
cyBTeXN0ZW1zMRUwEwYDVQQDEwxKYXNvbiBSaWNsZXMwggEiMA0GCSqGSIb3DQEB 
AQUAA4IBDwAwggEKAoIBAQCsha/dfnWIibmtySZuE8H+3AOa8/QuARKsFgmZJmWZ 
ZErjlzN6liUO1Q9pzYXoka69tiIOw0KDWwGAHCAK8mjNpdcs9XiYq3QMZjNAUhqP 
rRU5oDn9jwCwQnpepBhH6uiMaBcvrMsvLTaD4HvwoVyMROEhIWywBYMdHk86gcGr 
ALz+iMhE8017CAA2n/35fqwDjxeGxDgY3Ove/fTKoeA+ItKOwsYeFZUeej9omTz+ 
UcdXJ6fu312At/Sh7YZpgP3LsX+rMfdD9sHn80UTy46UoT5UNW0Me40+S47/oh4H 
VeOeR5XpcBPHnqbAJAvPAqD/sF9xbvhESwfoSkMB26drAgMBAAGjITAfMB0GA1Ud 
DgQWBBQ7YV0yIawkjCCp0crz52BGwMPHnzANBgkqhkiG9w0BAQsFAAOCAQEAdmwo 
8ZXZMxKzyfolVKj2UQBzkeSies133nRns0jFbkzm8N4lNtcWiShfLtlTQAuUZNMl 
JK7Eax+weLq7tNMZyBdLWse8E4oe8m3XY/Xe7oQGs2EzdlHVZk7JuDHU63mC33cz 
xvoNutE+y1Zonce9WaxACuNNMuxyYTVg6yqz/psjYE2YOajc1MmXjI38FkfmQ1bL 
ByeNEvnLT1IcQ0OmaSuk2ESj144y/EtkN9/GKFOTPjSRL3zIStNBytn7WNlFV/ch 
qaF/eOJRQMlHDosX40IrkHHIoc/pbTKYmjoreC/+biMKc0gUk+EN/uBrcJrVRFnl 
dXTNJe6/sNzvkTc/IA== 
-----END CERTIFICATE----- 

ar e устанавливается правильно.

Однако, когда я запускаю мой код следующее сообщение об ошибке печатается, когда container.connectToServer(this, new URI(websocketServer)); побежал

javax.websocket.DeploymentException: The HTTP request to initiate the WebSocket connection failed 
     at org.apache.tomcat.websocket.WsWebSocketContainer.connectToServer(WsWebSocketContainer.java:434) ~[tomcat7-websocket.jar:7.0.68] 
     at org.apache.tomcat.websocket.WsWebSocketContainer.connectToServer(WsWebSocketContainer.java:184) ~[tomcat7-websocket.jar:7.0.68] 
     at 
cored.web.CoreWebSocket.openConnection(CoreWebSocket.java:278) [cored.jar:3.0.10.160712122615] 
     at cored.web.CoreWebSocket.establishConnection(CoreWebSocket.java:1150) [cored.jar:3.0.10.160712122615] 
     at 
cored.web.CoreWebSocket.access$100(CoreWebSocket.java:85) [cored.jar:3.0.10.160712122615] 
     at 
cored.web.CoreWebSocket$2.execute(CoreWebSocket.java:138) [cored.jar:3.0.10.160712122615] 
     at utils.AThread.run(AThread.java:51) 
[utils.jar:3.0.10.160712122615] 
    Caused by: java.util.concurrent.ExecutionException: javax.net.ssl.SSLHandshakeException: General SSLEngine problem 
     at org.apache.tomcat.websocket.AsyncChannelWrapperSecure$WrapperFuture.get(AsyncChannelWrapperSecure.java:511) ~[tomcat7-websocket.jar:7.0.68] 
     at org.apache.tomcat.websocket.WsWebSocketContainer.connectToServer(WsWebSocketContainer.java:379) ~[tomcat7-websocket.jar:7.0.68] 
     ... 6 more 
    Caused by: javax.net.ssl.SSLHandshakeException: General SSLEngine problem 
     at sun.security.ssl.Handshaker.checkThrown(Unknown Source) ~[?:1.8.0_92] 
     at sun.security.ssl.SSLEngineImpl.checkTaskThrown(Unknown Source) ~[?:1.8.0_92] 
     at sun.security.ssl.SSLEngineImpl.writeAppRecord(Unknown Source) ~[?:1.8.0_92] 
     at sun.security.ssl.SSLEngineImpl.wrap(Unknown Source) ~[?:1.8.0_92] 
     at javax.net.ssl.SSLEngine.wrap(Unknown Source) ~[?:1.8.0_92] 
     at org.apache.tomcat.websocket.AsyncChannelWrapperSecure$WebSocketSslHandshakeThread.run(AsyncChannelWrapperSecure.java:371) ~[tomcat7-websocket.jar:7.0.68] 
    Caused by: javax.net.ssl.SSLHandshakeException: General SSLEngine problem 
     at sun.security.ssl.Alerts.getSSLException(Unknown Source) ~[?:1.8.0_92] 
     at sun.security.ssl.SSLEngineImpl.fatal(Unknown Source) ~[?:1.8.0_92] 
     at sun.security.ssl.Handshaker.fatalSE(Unknown Source) ~[?:1.8.0_92] 
     at sun.security.ssl.Handshaker.fatalSE(Unknown Source) ~[?:1.8.0_92] 
     at sun.security.ssl.ClientHandshaker.serverCertificate(Unknown Source) ~[?:1.8.0_92] 
     at sun.security.ssl.ClientHandshaker.processMessage(Unknown Source) ~[?:1.8.0_92] 
     at sun.security.ssl.Handshaker.processLoop(Unknown Source) ~[?:1.8.0_92] 
     at sun.security.ssl.Handshaker$1.run(Unknown Source) ~[?:1.8.0_92] 
     at sun.security.ssl.Handshaker$1.run(Unknown Source) ~[?:1.8.0_92] 
     at java.security.AccessController.doPrivileged(Native Method) ~[?:1.8.0_92] 
     at sun.security.ssl.Handshaker$DelegatedTask.run(Unknown Source) ~[?:1.8.0_92] 
     at org.apache.tomcat.websocket.AsyncChannelWrapperSecure$WebSocketSslHandshakeThread.run(AsyncChannelWrapperSecure.java:397) ~[tomcat7-websocket.jar:7.0.68] 
    Caused by: java.security.cert.CertificateException: No X509TrustManager implementation available 
     at sun.security.ssl.DummyX509TrustManager.checkServerTrusted(Unknown Source) ~[?:1.8.0_92] 
     at sun.security.ssl.ClientHandshaker.serverCertificate(Unknown Source) ~[?:1.8.0_92] 
     at sun.security.ssl.ClientHandshaker.processMessage(Unknown Source) ~[?:1.8.0_92] 
     at sun.security.ssl.Handshaker.processLoop(Unknown Source) ~[?:1.8.0_92] 
     at sun.security.ssl.Handshaker$1.run(Unknown Source) ~[?:1.8.0_92] 
     at sun.security.ssl.Handshaker$1.run(Unknown Source) ~[?:1.8.0_92] 
     at java.security.AccessController.doPrivileged(Native Method) ~[?:1.8.0_92] 
     at sun.security.ssl.Handshaker$DelegatedTask.run(Unknown Source) ~[?:1.8.0_92] 
     at org.apache.tomcat.websocket.AsyncChannelWrapperSecure$WebSocketSslHandshakeThread.run(AsyncChannelWrapperSecure.java:397) ~[tomcat7-websocket.jar:7.0.68] 

Я знаю .cer файл я использую не поврежден, так как он не используется также на TOMCAT веб-сервер и не имеет проблема.

Что может быть причиной этой ошибки No X509TrustManager implementation available?

ответ

5

.cer файл недопустим для вашего доверия. Вы можете использовать системную переменную javax.net.ssl.trustStoreType для установки типа. По умолчанию установлено значение JKS, вы также можете использовать PKCS12.

Вам необходимо создать файл JKS и включить файл .cer. Настройка и пароль для trusttore

System.setProperty("javax.net.ssl.trustStore", "path/to/truststore"); 
System.setProperty("javax.net.ssl.trustStorePassword", truststorepassword); 

Чтобы импортировать файл .cer в использовании JKS

keytool -importcert -file certificate.cer -keystore keystore.jks -alias "Alias" 
+0

так, если я установить доверие магазин с помощью системной переменной в '.cer' типа I Should будь умницей? Мы должны использовать '.cer' и не можем найти способ обойти его с соображениями безопасности. – jgr208

+0

Вы не можете использовать сам файл '.cer', потому что это не тип файла KeyStore, принятый JDK. Вы должны включить содержимое '.cer' в файл JKS. Уровень безопасности один и тот же, это просто проблема преобразования формата. Я задал в ответе, как импортировать .cer – pedrofb

+0

спасибо большое! взял меня около трех дней, пока я должен был сдаться и приехать сюда, разве это не безопасность? – jgr208

Смежные вопросы