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

Documents Java Discussion :

Sécurité des pages JSF


Sujet :

Documents Java

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Juin 2017
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Juin 2017
    Messages : 6
    Points : 9
    Points
    9
    Par défaut Sécurité des pages JSF
    Bonjour;
    j'utilise Netbeans comme IDE, glassfish comme serveur et JSF(Primefaces) comme Framework.
    je m'authentifie sur ma page index afin d'avoir accès au menu de mes pages. Mon problème est le
    suivant: sans s'authentifier, quelqu'un peut juste saisir le nom (accueil.xhtml par exemple) sur la bare URL de mon navigateur
    et accéder à ma page d'accueil. ce que je veux pas, comment puis-je interdire cela?
    quand je mets mes pages dans mon web-inf, je sais plus comment les récupérer.
    merci de me répondre.

  2. #2
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    Comment tu as mis en place ton authentification? Normalement il suffit d'indiquer ces page comme nécessitant d'être authentifié. A la riguer avec un role particulier si tu veux limiter plus. Ca se fait sur base de l'url.

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2014
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Conseil

    Informations forums :
    Inscription : Novembre 2014
    Messages : 7
    Points : 9
    Points
    9
    Par défaut
    Dans le contrôleur j'ai créé une méthode qui recherche un user par son login et passwprd. Si le user est trouvé, alors retourne moi "accueil.xhtml ? redirect=true" et return " " au cas contraire. Ça fonctionne bien mais le problème c'est si quelqu'un connaît qu'il y a une page accueil.xhtml et il part sur la barre URL remplacer index. Xhtml par accueil. Xhtml, il aura ma page accueil sans être identifié

  4. #4
    Membre expérimenté Avatar de Cincinnatus
    Homme Profil pro
    Développeur d'applications métier
    Inscrit en
    Mars 2007
    Messages
    592
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Développeur d'applications métier
    Secteur : Service public

    Informations forums :
    Inscription : Mars 2007
    Messages : 592
    Points : 1 679
    Points
    1 679
    Par défaut
    Le principe du contrôle d'accès repose, en JSF ou autre techno Java Web, sur l'utilisation de filtres.

    Exemples : https://thierrywasyl.wordpress.com/2...filter-in-jsf/
    https://www.journaldev.com/7252/jsf-...tabase-example

    On indique dans le web.xml que chaque requête doit passer par un filtre, lequel peut vérifier via la session ou la requête si l'utilisateur est connecté, quels ont ses droits... et autoriser la redirection selon l'url demandée et les droits de l'utilisateur.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
       <filter>        
         <filter-name>Controle Acces</filter-name>
            <filter-class>fr.demo.web.AccesFilter</filter-class>
        </filter>
    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
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
     
    import javax.servlet.Filter;
    import javax.servlet.FilterChain;
    import javax.servlet.FilterConfig;
    import javax.servlet.ServletException;
    import javax.servlet.ServletRequest;
    import javax.servlet.ServletResponse;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    import javax.servlet.http.HttpSession;
     
     
    public class AccesFilter implements Filter {
    ...
     
     
        @Override
        public void doFilter(ServletRequest req, ServletResponse res,
                FilterChain chain) throws IOException, ServletException {
     
     
            HttpServletRequest request = (HttpServletRequest) req;
            HttpServletResponse response = (HttpServletResponse) res;
     
     
            HttpSession session = (HttpSession) request.getSession();
     
            // utilisateur connu ?
            Utilisateur utilisateur = (Utilisateur) session.getAttribute(Utilisateur.UTILISATEUR);
            boolean droitsOk = false;
     
     
            if (utilisateur != null) {
     
                String path = request.getRequestURI().substring(request.getContextPath().length());
                            // les URl sont du type /agent/action.xhtml , /admin/action.xhtml, ...
                if (path.contains("/agent/")) {
                    if (utilisateur.isAgent())     {
                        droitsOk = true;
                    }
                }
                if (path.contains("/admin/")) {
                    if (utilisateur.isAdmin()) {
                        droitsOk = true;
                    }
                }
            }
     
     
            if (droitsOk) { // on pousuit la requête
                chain.doFilter(req, res);
            } else { // oops, redirection
                response.sendRedirect(request.getContextPath() + redirectionAccesDroitsInsuffisantsUrl);
            }
     
     
        }

  5. #5
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2014
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Conseil

    Informations forums :
    Inscription : Novembre 2014
    Messages : 7
    Points : 9
    Points
    9
    Par défaut
    OK Merci, je vais implémenter avant de voir

  6. #6
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    Sachant que java EE a déjà un controle d'accès implémenté si tu utilise tomcat, wildfly ou assimilés. Pas besoin de se coltiner une sécurité à la main si t'as juste des besoins standards.

    https://docs.oracle.com/javaee/6/tut...doc/bnbwj.html

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

Discussions similaires

  1. login jsf + sécurité des pages
    Par Delphives dans le forum JSF
    Réponses: 8
    Dernier message: 06/06/2009, 20h28
  2. Validation de la sécurité des pages Web
    Par Benzeghiba dans le forum SharePoint
    Réponses: 5
    Dernier message: 21/02/2009, 19h07
  3. Réponses: 3
    Dernier message: 25/11/2008, 15h27
  4. Sécurité des pages
    Par anisj1m dans le forum JSF
    Réponses: 5
    Dernier message: 10/07/2008, 13h07
  5. La sécurité des pages Asp
    Par dachir dans le forum ASP.NET
    Réponses: 4
    Dernier message: 28/03/2008, 11h15

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