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

Langage PHP Discussion :

[Sécurité] Affichages d'une page avec différents droits d'accès


Sujet :

Langage PHP

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    102
    Détails du profil
    Informations personnelles :
    Âge : 53
    Localisation : France, Yvelines (Île de France)

    Informations forums :
    Inscription : Juin 2005
    Messages : 102
    Points : 80
    Points
    80
    Par défaut [Sécurité] Affichages d'une page avec différents droits d'accès
    Voilà mon interrogation.

    Pour une page web affichée, je souhaiterais afficher différents éléments en fonction de droits d'accès.
    Y a-t-il une technique particulière évitant de faire des tests "un peu partout" en fonction des droits ?
    Je ne sais pas si je suis clair dans mes expliquations mais je vous remercie d'avance pour vos réponses.

  2. #2
    Rédacteur

    Avatar de Yoteco
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2004
    Messages
    1 099
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : Suisse

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

    Informations forums :
    Inscription : Décembre 2004
    Messages : 1 099
    Points : 2 498
    Points
    2 498
    Par défaut
    Personnellement je travaille avec des niveau d'accès ce qui me permet de tout tester avec un seul if. Je te donne un exemple:

    Tu crées tes différents goupres:
    • Membres [1]
    • Modérateurs [2]
    • Administrateurs [3]


    Et dans ta base de donnée tu ajoutes un champs "access_level" dans lequel tu stockes le niveau d'accès que j'ai mis entre []. C'est pratique car dans 90% des cas les pages que les membres peuvent voir les Modérateurs et les Administrateurs le peuvent aussi. Ensuite moi je répértorie toutes mes pages dans une base de données ou je met l'ID de la page puis l'ID de la page parent (s'il y en a une...) et le niveau d'accès de la page. Puis sur ta page index.php tu n'as plus qu'à tester
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
     
    // Tu fais un query sur la base pour retrouver le niveau d'accès de la page grâce à l'id de la page... Et normalement tu met le niveau d'accès de l'utilisateur dans une SESSION
     
    if($_SESSION['userLevel'] >= $pageLevel)
    { 
         //affiche page
    }
    else
    { 
         //erreur d'accès
    }
    Voilà c'est un système très simple mais qui fonctionne. Seul petit défaut c'est que toutes tes pages doivent être répértoriées, mais sa peut aussi être un avantage...
    Blog - Mon espace developpez -
    Oracle Certified Professional, Java SE 6 Programmer
    eZ Publish Certified developer

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    102
    Détails du profil
    Informations personnelles :
    Âge : 53
    Localisation : France, Yvelines (Île de France)

    Informations forums :
    Inscription : Juin 2005
    Messages : 102
    Points : 80
    Points
    80
    Par défaut
    Merci pour ta réponse mais ça je connaissais.
    Je me suis mal expliqué. En fait, c'est à l'intérieur d'une page que je souhaiterais afficher des éléments en fonction des droits (par exemple, un boîte toto pour les membres, et une boîte toto et une tata pour les admins, et pas de boîte pour les invités).

  4. #4
    Inactif  
    Avatar de Kerod
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    11 672
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 11 672
    Points : 20 778
    Points
    20 778
    Par défaut
    Même principe tu testes ta variable session ou ton champ bdd. Mais il serait plus judicieux de récuperer les informations connexion du membre et les mettre en SESSION. Puis dans ton script gérer les différents cas à coup de if

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    if($_SESSION['userlevel'] == ADMINISTRATEUR)
    //traitement
    else if....
    avec ADMINISTRATEUR un constante définit à l'aide d'un define

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    102
    Détails du profil
    Informations personnelles :
    Âge : 53
    Localisation : France, Yvelines (Île de France)

    Informations forums :
    Inscription : Juin 2005
    Messages : 102
    Points : 80
    Points
    80
    Par défaut
    Citation Envoyé par Kerod
    ...Puis dans ton script gérer les différents cas à coup de if

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    if($_SESSION['userlevel'] == ADMINISTRATEUR)
    //traitement
    else if....
    avec ADMINISTRATEUR un constante définit à l'aide d'un define
    C'est bien ce que je voudrais éviter. Y pas d'astuces de programmation qui pourraient éviter ça ?

  6. #6
    Inactif  
    Avatar de Kerod
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    11 672
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 11 672
    Points : 20 778
    Points
    20 778
    Par défaut
    Il te faudra quand même faire un traitement de condition pour les différents affichages. Sinon côté sécurité, j'ai dis une grosse bétise car si on arrive à récupérer ton id session on pourra avoir accès à ton administration

  7. #7
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    102
    Détails du profil
    Informations personnelles :
    Âge : 53
    Localisation : France, Yvelines (Île de France)

    Informations forums :
    Inscription : Juin 2005
    Messages : 102
    Points : 80
    Points
    80
    Par défaut
    Citation Envoyé par Kerod
    Il te faudra quand même faire un traitement de condition pour les différents affichages.
    OK merci
    Citation Envoyé par Kerod
    Sinon côté sécurité, j'ai dis une grosse bétise car si on arrive à récupérer ton id session on pourra avoir accès à ton administration
    Tu me conseilles quoi alors ? Je comptais gérer çà via les sessions

  8. #8
    Rédacteur

    Avatar de Yoteco
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2004
    Messages
    1 099
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : Suisse

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

    Informations forums :
    Inscription : Décembre 2004
    Messages : 1 099
    Points : 2 498
    Points
    2 498
    Par défaut
    Tu peux sécuriser tes sessions avec une base de donnée ou alors tu enregistres l'ip de l'utilisateur. Y a un tuto sur la sécurisation des sessions >>ICI<<
    Blog - Mon espace developpez -
    Oracle Certified Professional, Java SE 6 Programmer
    eZ Publish Certified developer

  9. #9
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    102
    Détails du profil
    Informations personnelles :
    Âge : 53
    Localisation : France, Yvelines (Île de France)

    Informations forums :
    Inscription : Juin 2005
    Messages : 102
    Points : 80
    Points
    80
    Par défaut
    Merci pour tout.

  10. #10
    Membre éclairé
    Avatar de jc_cornic
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    623
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 623
    Points : 823
    Points
    823
    Par défaut
    Juste pour clore la discussion, pensez à cocher "résolu" quand c résolu
    VELOMASTER, idée cadeau ? un jeu de plateau

    Hummmmm, des donuts !!!!

    Merci de penser à , et et aussi

  11. #11
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    102
    Détails du profil
    Informations personnelles :
    Âge : 53
    Localisation : France, Yvelines (Île de France)

    Informations forums :
    Inscription : Juin 2005
    Messages : 102
    Points : 80
    Points
    80
    Par défaut
    Citation Envoyé par jc_cornic
    Juste pour clore la discussion, pensez à cocher "résolu" quand c résolu
    Oups ! désolé. Voilà qui est fait

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

Discussions similaires

  1. [WB19] Difficultés d'affichage d'une page avec IIS7
    Par Tito47 dans le forum WebDev
    Réponses: 2
    Dernier message: 19/05/2014, 10h07
  2. Affichage d'une page avec IE 9
    Par mcdelay dans le forum Général Conception Web
    Réponses: 0
    Dernier message: 21/02/2014, 16h22
  3. ajuster une page avec diffèrent ecrans
    Par k_boy dans le forum Mise en page CSS
    Réponses: 4
    Dernier message: 30/05/2011, 09h59
  4. affichage d'une page html avec un iframe
    Par JCD21 dans le forum Général JavaScript
    Réponses: 0
    Dernier message: 14/04/2008, 20h34
  5. Affichage d'une page HTML avec SDL
    Par Henri dans le forum SDL
    Réponses: 4
    Dernier message: 13/04/2008, 11h30

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