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

C++ Discussion :

Modification du mot de passe active directory avec open ldap


Sujet :

C++

  1. #1
    Nouveau membre du Club
    Profil pro
    Formateur en informatique
    Inscrit en
    Mars 2010
    Messages
    32
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Formateur en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Mars 2010
    Messages : 32
    Points : 35
    Points
    35
    Par défaut Modification du mot de passe active directory avec open ldap
    Bonjour tout le monde

    Je développe un programme qui gère l'active directory avec open ldap.
    J'arrive à me connecter, à ajouter un utilisateur, à le supprimer mais je n'arrive pas à modifier son mot de passe. Impossible de trouver quelque chose sur le net. Es que quelqu'un peut m'aider. J'aimerais pouvoir modifier son mot de passe.

    Il existe une fonction ldap_modify_s qui permet de modifier un objet de l'active directory.

    J'ai trouver ce code mais il me renvois une erreur à l'execution.
    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
    58
    59
    60
     
    LDAP *ld;
        char *ldap_host = "mondomaine.fr";
        int ldap_port = 389;
        char *root_dn = "CN=moi,OU=utilisateurs,DC=domaine,DC=fr";
        char *root_pwd = "monpassadmin";
        char *base;
     
    //modifier mot de passe dans AD
                BerElement* ber;
                LDAPMessage* msg;
                LDAPMessage* entry;
     
                if ((ld = ldap_init(ldap_host,ldap_port))== NULL)QMessageBox::critical(0, QObject::tr("Erreur ldap"), "Pas initialiser");
                if(ldap_simple_bind_s(ld,root_dn,root_pwd) != LDAP_SUCCESS)QMessageBox::critical(0, QObject::tr("Erreur ldap"), "ldap_bind not connected");
     
                baseString = "cn="+query.value(13).toString()+", OU=groupes,DC=mondomaine,DC=fr";
                base = baseString.toAscii().data();
     
                ulong err = 1;
                LDAPMod modPassword;
                LDAPMod *modEntry[2];
                berval pwdBerVal;
                berval *pwd_attr[2];
                wchar_t pszPasswordWithQuotes[1024];
     
                // Crée un tableau de LDAPMod.
                // Pour le paramètre unicodePwd, ceci DOIT être un op. simple
                modEntry[0] = &modPassword;
                modEntry[1] = NULL;
     
                // Crée le struct mod pour l'attribut unicodePwd.
                modPassword.mod_op = LDAP_MOD_REPLACE | LDAP_MOD_BVALUES;
                modPassword.mod_type = "unicodePwd";
                modPassword.mod_vals.modv_bvals = pwd_attr;
     
                // Le mot de passe aura une valeur unique, donc nous avons un seul élément.
                pwd_attr[0] = &pwdBerVal;
                pwd_attr[1]= NULL;
     
                // Place le mot de passe entre guillemets.
                wsprintf(pszPasswordWithQuotes,L"\"%s\"",mdpgenerer);
     
                // Crée la structure BER avec le mot de passe UNICODE.
                pwdBerVal.bv_len = wcslen(pszPasswordWithQuotes) * sizeof(wchar_t);
                pwdBerVal.bv_val = (char*)pszPasswordWithQuotes;
     
     
                // Exécute une modification individuelle.
                err = ldap_modify_s(ld,
                                                base,
                                                modEntry
                                                );
     
                        if (err == LDAP_SUCCESS )
                                qDebug()<<("\nMot de passe défini correctement !\n");
                        else
                                qDebug()<<("\nÉchec lors de la définition du mot de passe !\n");
     
                        qDebug()<<err;
    ca s'arrete là :

    pwd_attr[1]= NULL; -> illegal instruction par le signal SIGILL

    Pouvez vous m'aider please
    merci d'avance

  2. #2
    Nouveau membre du Club
    Profil pro
    Formateur en informatique
    Inscrit en
    Mars 2010
    Messages
    32
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Formateur en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Mars 2010
    Messages : 32
    Points : 35
    Points
    35
    Par défaut
    Personne peut m'aider ? je suis toujours devant le même problème.

    Quitte à m'orienter vers une autre procédure.

Discussions similaires

  1. synchronisation mots de passe Active Directory via IIFP sans PCNS
    Par CGR15121 dans le forum Windows Serveur
    Réponses: 1
    Dernier message: 20/03/2012, 18h36
  2. Réponses: 6
    Dernier message: 18/08/2011, 13h27
  3. Mise à jour du mot de passe Active Directory
    Par katyrd dans le forum Sécurité
    Réponses: 0
    Dernier message: 05/08/2011, 09h35
  4. Réponses: 4
    Dernier message: 21/04/2010, 11h35
  5. [LDAP] Mots de passe active directory via php
    Par chtijule dans le forum Bibliothèques et frameworks
    Réponses: 2
    Dernier message: 15/08/2009, 11h54

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