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

Bibliothèques et frameworks PHP Discussion :

[LDAP] Récupération de mot de passe user sous openLDAP Mac OSX en PHP


Sujet :

Bibliothèques et frameworks PHP

  1. #1
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 4
    Points : 1
    Points
    1
    Par défaut [LDAP] Récupération de mot de passe user sous openLDAP Mac OSX en PHP
    Bonjour,

    désolé de vous embêter encore , je réalise un script de login en PHP qui s'interface sur le serveur OpenLDAP de Mac OSX...

    Le problème est que je ne comprend pas trop son fonctionnement avec Kerberos, et je n'arrive pas à récupérer le champ mot de passe (dsAttrTypeNative:UserPassword)

    Ca ne me renvoie même pas de chaine cryptée... Alors que le champ "dsAttrTypeNative:mail" est bien renvoyé, ainsi que les autres...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    for ($i=0; $i<$info["count"]; $i++) {
           echo 'dn est : ' . $info[$i]["dn"] . '<br />';
           echo 'premiere entree cn : ' . $info[$i]["cn"][0] . '<br />';
           echo 'premier email : ' . $info[$i]["mail"][0] . '<br />';
           echo 'mdp : ' . $info[$i]["userPassword"] . '<br />';
       }
    Quelqu'un pourrait-il m'éclairer svp ?

  2. #2
    Membre averti
    Inscrit en
    Janvier 2004
    Messages
    533
    Détails du profil
    Informations forums :
    Inscription : Janvier 2004
    Messages : 533
    Points : 313
    Points
    313
    Par défaut
    Bonjour,

    je n'en suis pas sûre, mais peut-être qu'un champ mot de passe ne peut pas être récupéré...
    N'oubliez pas le tag .
    Merci de ne pas envoyer de MP pour des problèmes techniques.

  3. #3
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 4
    Points : 1
    Points
    1
    Par défaut
    Ainsi il serait impossible d'utiliser le serveur LDAP comme serveur d'Authentification lors des phases de login en php ?

  4. #4
    Expert éminent sénior

    Profil pro
    Inscrit en
    Juin 2002
    Messages
    6 152
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 6 152
    Points : 17 778
    Points
    17 778
    Par défaut
    Citation Envoyé par navis84
    je n'en suis pas sûre, mais peut-être qu'un champ mot de passe ne peut pas être récupéré...
    Tout dépend des ACL : les permissions pour un utilisateur (anonyme, authentifié, ...) à accéder aux données (lecture, écriture, ...). Mais avec kerberos, si j'ai bonne mémoire, ce champ (userPassword) ressemble à une adresse email pour justement utiliser le protocole Kerberos.


    Julp.

  5. #5
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 4
    Points : 1
    Points
    1
    Par défaut
    Je ne sais pas, ce champ est crypté lorsqu'on y accède... Et vu qu'on ne peut le récupérer en php...

    En tout cas j'ai trouvé la solution, il suffit de faire un ldap_bind avec les identifiants entrés et de tester la valeur de retour (False, True).

    L'inconvénient de cette méthode est qu'elle affiche un warning en cas d'échec... Existe-t-il une solution pour ne pas afficher de warning dans un script donné sans les désactiver dans le php.ini ?

    Merci de vos réponses

  6. #6
    Expert confirmé
    Avatar de Sub0
    Homme Profil pro
    Développeur Web
    Inscrit en
    Décembre 2002
    Messages
    3 573
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Décembre 2002
    Messages : 3 573
    Points : 4 219
    Points
    4 219
    Par défaut
    Citation Envoyé par 3mPty
    Existe-t-il une solution pour ne pas afficher de warning dans un script donné sans les désactiver dans le php.ini ?

    Merci de vos réponses
    En faisant précéder la fonction d'un arobas (@), celle-ci ne déclenchera pas de warning.
    Exemple, si le champs "test" n'est pas posté, en temps normal, le code suivant génère une erreur sans l'arobas. Il faudrait alors tester le champs avec isset avant de vouloir l'utiliser :

    $test=@$_POST['test'];

    Dans cet exemple, $test vaut 0 si le champs n'est pas posté, à+

    ps: Probable que cela doit fonctionner différemment selon la version du PHP & Apache utilisées...
    De retour parmis vous après 10 ans!!

  7. #7
    Expert éminent sénior

    Profil pro
    Inscrit en
    Juin 2002
    Messages
    6 152
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 6 152
    Points : 17 778
    Points
    17 778
    Par défaut
    Citation Envoyé par 3mPty
    Je ne sais pas, ce champ est crypté lorsqu'on y accède... Et vu qu'on ne peut le récupérer en php...
    Encore de mémoire, l'attribut userPassword est stocké sous forme binaire donc utilise un "encodage" base64 : voir les fonctions base64_encode() et base64_decode().

    Toutefois, avant de foncer tête baissée dans la programmation en PHP, il serait peut être plus judicieux de comprendre un minimum comment fonctionne LDAP/OpenLDAP et Kerberos.


    Julp.

  8. #8
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 4
    Points : 1
    Points
    1
    Par défaut
    Citation Envoyé par julp
    Toutefois, avant de foncer tête baissée dans la programmation en PHP, il serait peut être plus judicieux de comprendre un minimum comment fonctionne LDAP/OpenLDAP et Kerberos.
    Je ne demande pas mieux, seulement je n'ai pas trouvé de bons tuto sur une application concrète de ces deux composants... Si tu connais une bonne doc je suis preneur...

    Merci à Sub0 pour l'astuce de l'arobase, qui fonctionne parfaitement !

Discussions similaires

  1. [LDAP] Requête pour vérifier le login et mot de passe
    Par NiGHtyWolf dans le forum Bibliothèques et frameworks
    Réponses: 1
    Dernier message: 10/03/2007, 22h44
  2. mot de passe administrateur sous xp
    Par GIPPE dans le forum Windows XP
    Réponses: 1
    Dernier message: 19/12/2006, 19h22
  3. Réinitialiser mot de passe user postgres
    Par Teufboy dans le forum PostgreSQL
    Réponses: 3
    Dernier message: 30/08/2006, 09h07
  4. Réponses: 3
    Dernier message: 23/02/2006, 11h19

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