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

JSF Java Discussion :

login jsf + sécurité des pages


Sujet :

JSF Java

  1. #1
    Nouveau membre du Club
    Profil pro
    ----
    Inscrit en
    Février 2005
    Messages
    27
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : ----

    Informations forums :
    Inscription : Février 2005
    Messages : 27
    Points : 25
    Points
    25
    Par défaut login jsf + sécurité des pages
    Bonjour,

    Voila mon problème :
    j'aimerais faire une petite appli web avec le fonctionnalités suivantes :

    - application avec technologie jsf
    - lors du lancement de l'application, la page d'accueil doit etre welcome.jsp
    - si l'utilisateur s'est authentifié, il est directement redirigé vers la page welcome.jsp qui affiche son nom, sinon il atterit sur la page login.jsp
    - lors de la validation dans login.jsp, c'est la méthode d'une classe (appelée par le bouton) qui va récupérer le nom d'utilisateur + mot de passe et qui va le comparer à des valeurs dans un fichier contenant les combinaisons user+password. si l'authentification est correcte, redirection vers welcome.jsp avec un lien pour se déconnecter (logout.jsp).

    mon soucis n'est pas l'algorithme de la classe qui va permettre l'authentification ou non, mais de savoir ce que la fonction doit retourner ou effectuer si le login ok ou non.

    merci d'avance pour votre aide, car j'ai de la peine à trouver un exemple sur le web qui ressemble à ce que je recherche.

    ++

  2. #2
    Membre à l'essai
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    18
    Détails du profil
    Informations personnelles :
    Localisation : France, Indre et Loire (Centre)

    Informations forums :
    Inscription : Juin 2008
    Messages : 18
    Points : 20
    Points
    20
    Par défaut
    Bonjour,
    a mon avis tu devrais regarder du cote de JAAS et des pricipes d'identification et d'autorisation JAVA EE.
    Jettes un coup d oeil sur la doc tomcat sur la mise en oeuvre d un realm
    http://tomcat.apache.org/tomcat-6.0-...alm-howto.html
    et sur la reference de SUN
    http://java.sun.com/j2se/1.4.2/docs/...als/index.html

    C est assez impressionnant au début, mais en fait c'est assez simple à configurer (web.xml et serveur)

    bon courage

  3. #3
    Nouveau membre du Club
    Profil pro
    ----
    Inscrit en
    Février 2005
    Messages
    27
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : ----

    Informations forums :
    Inscription : Février 2005
    Messages : 27
    Points : 25
    Points
    25
    Par défaut
    Bonjour,

    merci pour ces liens. A tout hasard, connaisseriez-vous une adresse où je puisse télécharger un petit exemple de ce que je cherche. Cela me parait étrange que personne n'aie parler de ça auparavant.

    merci et bonne journée

  4. #4
    Nouveau membre du Club
    Inscrit en
    Juin 2008
    Messages
    30
    Détails du profil
    Informations forums :
    Inscription : Juin 2008
    Messages : 30
    Points : 37
    Points
    37
    Par défaut
    tu crée un managed bean "Auth" de scope session qui a comme attributs login et pass, et une methode "authentifier" qui verifie les login et pass et retourn un String qui prend deux valeurs: si login et pass sont valides elle retourne un string qui doit etre déclaré dans une navigation-rule dans faces-config.xml, et qui mène vers ta welcome.jsp. Sinon elle retourne un autre string qui doit etre déclaré dans une navigation-rule dans faces-config.xml, et qui mène vers ta login.jsp
    c'est aussi simple que ça

  5. #5
    Membre actif

    Inscrit en
    Décembre 2005
    Messages
    260
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 260
    Points : 208
    Points
    208
    Par défaut
    oui mais si on tape le URL de la page sécurisé directement que ce qui se passera?

  6. #6
    Membre du Club
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    110
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 110
    Points : 67
    Points
    67
    Par défaut
    Je crois que JSF permet de configurer les pages dont tu veux interdire l'accès en tapant l'adresse justement, ça se trouve dans le fichier web.xml. Je ne suis pas tout à fait sur, je ne l'ai jamais fait.

  7. #7
    Membre actif

    Inscrit en
    Décembre 2005
    Messages
    260
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 260
    Points : 208
    Points
    208
    Par défaut
    est ce qu'on met les utilisateurs et les rôles dans le serveur d'application ou il suffit de les mettre dans une base de données quelle est la solution la plus judicieuse??

  8. #8
    Membre à l'essai
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    18
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2009
    Messages : 18
    Points : 22
    Points
    22
    Par défaut
    Personnellement je te préconise JBoss Seam si tu as une BDD (EJB3). Tu auras un système de login simple et la possibilité de gérer les comportements lors de la tentative d'accès à une page avant et après login avec ou sans JBPM.

    Voici un exemple :

    http://www.nofluffjuststuff.com/blog...with_seam.html

  9. #9
    Membre actif

    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    152
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 152
    Points : 264
    Points
    264
    Par défaut
    Pour ma part, j'ai "expérimenté" plusieurs petits trucs pour sécurisé des pages.
    Le premier consiste à bloquer l'accès aux pages sécurisé pour la méthode GET en ajoutant au fichier web.xml une règle de sécurité. Voici un exemple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
     <security-constraint>
            <web-resource-collection>
                <web-resource-name>Restrict access to JSP pages</web-resource-name>
                <url-pattern>/admin/*</url-pattern>
                <http-method>GET</http-method>
     
            </web-resource-collection>
            <auth-constraint>
                <description>With no roles defined, no access granted</description>
            </auth-constraint>
        </security-constraint>
    Donc toutes les pages de mon répertoire /admin seront inaccessibles si tu tapes l'adresse directement.

    Le deuxième, qui peut se combiner au premier, est de travailler avec un phase listener. Après la phase de restauration de la page (la première phase) on vérifie l'existence de la session, si elle n'existe pas on utilise un navigationHandler qui va, via une navigation rule, rediriger l'utilisateur vers la page voulue.

    La troisième solution que je vois est d'utiliser un filtre dont l'url pattern est du genre "/admin/". Si la session n'existe pas, alors on redirige.

Discussions similaires

  1. Validation de la sécurité des pages Web
    Par Benzeghiba dans le forum SharePoint
    Réponses: 5
    Dernier message: 21/02/2009, 19h07
  2. Sécurité des pages
    Par anisj1m dans le forum JSF
    Réponses: 5
    Dernier message: 10/07/2008, 13h07
  3. [JSF]extension des pages jsp
    Par la7su dans le forum JSF
    Réponses: 1
    Dernier message: 28/03/2008, 11h51
  4. La sécurité des pages Asp
    Par dachir dans le forum ASP.NET
    Réponses: 4
    Dernier message: 28/03/2008, 11h15
  5. Réponses: 1
    Dernier message: 29/05/2006, 10h04

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