IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Tomcat et TomEE Java Discussion :

Lecture d'un certificat client (navigateur)


Sujet :

Tomcat et TomEE Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé Avatar de thecanea
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    131
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Côte d'Or (Bourgogne)

    Informations forums :
    Inscription : Octobre 2008
    Messages : 131
    Par défaut Lecture d'un certificat client (navigateur)
    Bonjour,

    Je souhaiterai lire un certificat client (depuis le navigateur du client) et en "récupérer" le contenu pour l'afficher, etc. depuis une application java/jsp sur du Tomcat; mais je ne sais pas comment m'y prendre.

    Auriez vous des exemples de code java/jsp ou des pistes de comment faire pour y parvenir ??

    Merci par avance,

    Cordialement,

    Thecanea

  2. #2
    Membre confirmé Avatar de thecanea
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    131
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Côte d'Or (Bourgogne)

    Informations forums :
    Inscription : Octobre 2008
    Messages : 131
    Par défaut
    Pourriez-vous m'indiquer comment faire pour faire que Tomcat demande au navigateur un certificat (certificat client) ?

    Merci par avance...

  3. #3
    Modérateur
    Avatar de OButterlin
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    7 313
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 7 313
    Billets dans le blog
    1
    Par défaut
    Dans le web.xml, il faut positionner le groupe <security-constraint>, en particulier la partie <user-data-constraint> :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    <security-constraint> 
            ...
    <user-data-constraint> 
        <transport-guarantee>CONFIDENTIAL</transport-guarantee> 
    </user-data-constraint> 
    ...
    </security-constraint>
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  4. #4
    Membre confirmé Avatar de thecanea
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    131
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Côte d'Or (Bourgogne)

    Informations forums :
    Inscription : Octobre 2008
    Messages : 131
    Par défaut
    Alors pour répondre à mon problème :

    Il faut configurer Tomcat pour demander un certificat client, pour ce faire on édite le fichier server.xml de Tomcat.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
        <Connector protocol="org.apache.coyote.http11.Http11Protocol"
        port="8443" maxThreads="200" 
        scheme="https" secure="true" SSLEnabled="true" 
        keystoreFile="/opt/tomcat-ssl/tomcat.keystore" 
        keystorePass="pass" 
        clientAuth="true" sslProtocol="TLS"
        truststoreFile="/opt/tomcat-ssl/tomcat-truststore.jks" 
        truststorePass="pass" 
        truststoreType="JKS" />
    On ajoute dans un keystore les CA de confiance desquels on acceptera les certificats signés. C'est une étape très importante.

    Si on ne veut pas obliger la présence de certificat, on peut mettre la variable clientAuth à "want".

    Pour récupérer le contenu d'un certificat client, il suffira d'utiliser le code suivant depuis une simple jsp :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    <HTML>
    <BODY>
    <%@ page import="java.util.Set" %>
    <%@ page import="java.util.Iterator" %>
    <%@ page import="java.io.FileInputStream" %>
    <%@ page import="java.security.cert.*" %>
    <%@ page import="java.security.cert.CertificateFactory" %>
    <%@ page import="java.security.cert.X509Certificate" %>
    <%@ page import="javax.net.ssl.*" %>
    <%@ page import="java.io.*" %>       
        <p>Certificat ?? <br/> 
     
            <%
                X509Certificate[] certChain = (X509Certificate[])request.getAttribute("javax.servlet.request.X509Certificate");
     
                if (certChain != null) {
                    out.println("certificat trouvé");
     
                   for (int i=0; i < certChain.length; i++) {
                       out.println(certChain[i].toString());       
                       out.println(certChain[i].getVersion());       
                   }
                }
            %>
        </p>
    </BODY>
    </HTML>
    Pour davantage d'informations : http://java.sun.com/j2se/1.4.2/docs/...rtificate.html

    En espérant que ça puisse être utile à quelqu'un.

    Résolu.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 5
    Dernier message: 11/07/2008, 10h25
  2. Certificats clients pour cryptage document
    Par biniou14 dans le forum Sécurité
    Réponses: 1
    Dernier message: 10/06/2008, 13h11
  3. Detection erreur 403.7 (certificat client requis ) ASP.Net ou c#
    Par mr_mitchou dans le forum Général Dotnet
    Réponses: 5
    Dernier message: 27/02/2008, 14h33
  4. Lecture base de registre client
    Par locs dans le forum Général Conception Web
    Réponses: 3
    Dernier message: 02/02/2007, 10h03
  5. certificats clients sous IIS 6
    Par fredoche dans le forum ASP
    Réponses: 4
    Dernier message: 03/08/2006, 11h45

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo