2013-10-17 1 views
0

Je sais que c'est une question très simple, mais comment j'ai réussi à ne pas trouver de solution à ce problème. J'ai une classe Java qui a une méthode principale. Dans cette méthode, je tente d'accéder à une URL HTTPS comme ci-dessous:Comment accéder à une URL HTTPS à partir d'une application Java

package helloworld; 

import java.io.BufferedReader; 
import java.io.IOException; 
import java.io.InputStream; 
import java.io.InputStreamReader; 
import java.net.URL; 

import javax.net.ssl.HttpsURLConnection; 

public class ConnectHttps 
{ 
public static void main(String[] argsd) 
{ 
    System.out.println("***************Https testing started **************"); 
    try 
    { 
     URL u = new URL("https://localhost:8443/myapp/test"); 
     HttpsURLConnection http = (HttpsURLConnection) u.openConnection(); 
     http.setAllowUserInteraction(true); 
     http.setRequestMethod("GET"); 
     http.connect(); 

     InputStream is = http.getInputStream(); 
     BufferedReader reader = new BufferedReader(new InputStreamReader(is)); 
     StringBuilder stringBuilder = new StringBuilder(); 
     String line = null; 
     while ((line = reader.readLine()) != null) 
     { 
      stringBuilder.append(line 
       + "\n"); 
     } 
     System.out.println(stringBuilder.toString()); 
     System.out.println("***************Https testing completed **************"); 
    } 
    catch (IOException e) 
    { 
     System.out.println("***************Https testing failed **************"); 
     e.printStackTrace(); 
    } 
} 

} 

sur l'exécution de ce programme, la sortie que je reçois est:

***************Https testing started ************** 
***************Https testing failed ************** 
javax.net.ssl.SSLHandshakeException: java.security.cert.CertificateException: No name matching localhost found 
at sun.security.ssl.Alerts.getSSLException(Alerts.java:192) 
at sun.security.ssl.SSLSocketImpl.fatal(SSLSocketImpl.java:1886) 
at sun.security.ssl.Handshaker.fatalSE(Handshaker.java:276) 
at sun.security.ssl.Handshaker.fatalSE(Handshaker.java:270) 
at sun.security.ssl.ClientHandshaker.serverCertificate(ClientHandshaker.java:1341) 
at sun.security.ssl.ClientHandshaker.processMessage(ClientHandshaker.java:153) 
at sun.security.ssl.Handshaker.processLoop(Handshaker.java:868) 
at sun.security.ssl.Handshaker.process_record(Handshaker.java:804) 
at sun.security.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:1016) 
at sun.security.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.java:1312) 
at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1339) 
at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1323) 
at sun.net.www.protocol.https.HttpsClient.afterConnect(HttpsClient.java:515) 
at sun.net.www.protocol.https.AbstractDelegateHttpsURLConnection.connect(AbstractDelegateHttpsURLConnection.java:185) 
at sun.net.www.protocol.https.HttpsURLConnectionImpl.connect(HttpsURLConnectionImpl.java:153) 
at helloworld.ConnectHttps.main(ConnectHttps.java:59) 

Je suppose que je suis en train de faire une erreur très basique ici.

J'utilise JDK 1.7.0_25.

+0

@axiopisty Pourquoi? Si JSSE n'était pas correctement configuré, comment aurait-il pu compiler ce programme? Ou exécuté? Ou avez-vous une trace de pile contenant sun.security.ssl.SSLSocketImpl? – EJP

Répondre

2

java.net.ConnectException: Connection timed out: connect

Ce n'est pas vraiment lié à SSL/TLS. Au contraire, votre client ne peut pas se connecter au serveur (du moins pas dans un délai raisonnable).

Il est tout à fait possible qu'un pare-feu vous empêche d'établir de telles connexions.

Vous pourriez avoir à passer par un proxy, auquel cas la définition des propriétés du système https.proxyHost et https.proxyPort doivent être pris en compte par HttpsURLConnection.

+0

Merci pour la réponse [Bruno] (http://stackoverflow.com/users/372643/bruno). J'ai modifié ma question pour pointer vers une URL locale. J'ai donné une URL publique plus tôt afin que cela puisse être complet [sscce] (http://sscce.org/). J'obtiens l'exception: 'javax.net.ssl.SSLHandshakeException: java.security.cert.CertificateException: aucun nom correspondant localhost found'. J'ai fait mes recherches pour arriver à [ceci] (http://www.mkyong.com/webservices/jax-ws/java-security-cert-certificateexception-no-name-matching-localhost-found/), mais tout cela est en train de désactiver SSL. – Aspirant

+0

Essentiellement ce dont j'ai besoin est de pouvoir configurer des certificats de sécurité sur mon client, qui n'est pas un navigateur dans ce cas. – Aspirant

+0

Votre certificat n'est pas valide pour 'localhost'. Essayez d'utiliser le nom de domaine complet dans l'URL pour faire correspondre les éléments du certificat. – Bruno

Questions connexes