CONNEXION
  • RetourJeux
    • Sorties
    • Hit Parade
    • Les + populaires
    • Les + attendus
    • Soluces
    • Tous les Jeux
    • Gaming
  • RetourActu Gaming
    • News
    • Astuces
    • Tests
    • Previews
    • Toute l'actu gaming
  • RetourBons plans
    • Bons plans
    • Bons plans Smartphone
    • Bons plans Hardware
    • Bons plans Image et Son
    • Bons plans Amazon
    • Bons plans Cdiscount
    • Bons plans Decathlon
    • Bons plans Fnac
    • Tous les Bons plans
  • RetourJVTech
    • Actus High-Tech
    • Intelligence Artificielle
    • Smartphones
    • Mobilité urbaine
    • Hardware
    • Image et son
    • Tutoriels
    • Tests produits High-Tech
    • Guides d'achat High-Tech
    • JVTech
  • RetourCulture
    • Actus Culture
    • Culture
  • RetourVidéos
    • A la une
    • Gaming Live
    • Vidéos Tests
    • Vidéos Previews
    • Gameplay
    • Trailers
    • Chroniques
    • Replay Web TV
    • Toutes les vidéos
  • RetourForums
    • Hardware PC
    • PS5
    • Switch 2
    • Xbox Series
    • Switch
    • Pokemon pocket
    • FC 25 Ultimate Team
    • League of Legends
    • Tous les Forums
  • PC
  • PS5
  • Xbox Series
  • Switch 2
  • PS4
  • One
  • Switch
  • iOS
  • Android
  • MMO
  • RPG
  • FPS
En ce moment Genshin Impact Valhalla Breath of the wild Animal Crossing GTA 5 Red dead 2
Liste des sujets

httpclient : problème sites en https

[jack-sparrow]
[jack-sparrow]
Niveau 7
15 avril 2013 à 01:17:10

Salut !

Mon problème est très simple, je veux accéder au site https://ahrefs.com/ grâce à mon httpclient. Or pour les sites en "https" j'obtiens l'erreur javax.net.ssl.SSLPeerUnverifiedException: peer not authenticated.

Etant donné que je sais très bien que ce site est un site de confiance, comment puis-je faire pour ne plus avoir cette erreur ?

Merci d'avance et bonne soirée !

Pseudo supprimé
Pseudo supprimé 15 avril 2013 à 09:57:27

Bon. C'est mal...
Mais la façon la plus simple est de créer une implémentation de l'interface qui te pose problème (voir d'hériter et de surcharger une classe le faisant déjà) et de lui faire répondre "tout va bien, true".
C'est ce que j'avais fait pour passer un jeu de tests sur un environnement de développement où la boîte n'avait pas de "vrais" certificats.
En gros, tu vas avoir une classe remplie de méthodes presque vides.

_skip
_skip
Niveau 10
15 avril 2013 à 11:25:11

Il me semble qu'on pouvait faire ça en utilisant EasySSLProtocolSocketFactory.

[jack-sparrow]
[jack-sparrow]
Niveau 7
15 avril 2013 à 15:05:47

Salut !

J'ai essayé :

Protocol easyHttps = new Protocol("https", new EasySSLProtocolSocketFactory(), 443);

Protocol.registerProtocol("https", easyHttps);

Mais il reconnait pas le type Protocol...

Si j'ai bien compris faut aussi implémenter EasySSLProtocolSocketFactory mais j'ai beau copier les codes qu'ils donnent y'a toujours au moins 50 erreurs et des problèmes dans les imports.

Comment faire ?

Dbzgokussj2
Dbzgokussj2
Niveau 10
15 avril 2013 à 17:48:49

Y a pas de librairie cURL en JAVA qui gèrerait ça ? :(

Volodine
Volodine
Niveau 8
16 avril 2013 à 05:25:43

Voila une solution qui marche sur Android. A voir si elle marche en Jav

Volodine
Volodine
Niveau 8
16 avril 2013 à 05:26:30

a normal.

(oui bien mon fail tab ? :hap: )

private HttpClient sslClient(HttpClient client) {
try {
X509TrustManager tm = new X509TrustManager() {
public void checkClientTrusted(X509Certificate[] xcs, String string) throws CertificateException {
}

public void checkServerTrusted(X509Certificate[] xcs, String string) throws CertificateException {
}

public java.security.cert.X509Certificate[] getAcceptedIssuers() {
return null;
}

@Override
public void checkClientTrusted(
java.security.cert.X509Certificate[] chain,
String authType)
throws java.security.cert.CertificateException {
// TODO Auto-generated method stub

}

@Override
public void checkServerTrusted(
java.security.cert.X509Certificate[] chain,
String authType)
throws java.security.cert.CertificateException {
// TODO Auto-generated method stub

}
};
SSLContext ctx = SSLContext.getInstance("TLS");
ctx.init(null, new TrustManager[]{tm}, null);
SSLSocketFactory ssf = new MySSLSocketFactory(ctx);
ssf.setHostnameVerifier(SSLSocketFactory.ALLOW_ALL
_HOSTNAME_VERIFIER);

ClientConnectionManager ccm = client.getConnectionManager();
SchemeRegistry sr = ccm.getSchemeRegistry();
sr.register(new Scheme("https", ssf, 443));
return new DefaultHttpClient(ccm, client.getParams());
} catch (Exception ex) {
return null;
}
}

[jack-sparrow]
[jack-sparrow]
Niveau 7
20 avril 2013 à 17:47:00

Il faudrait que je mette ce code où ?

Sous forums
  • Aide à l'achat Mac
  • Création de Jeux
  • Linux
  • Programmation
  • Création de sites web
  • Internet
  • Steam Deck
  • Macintosh
  • Hardware
La vidéo du moment