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

Macros et VBA Excel Discussion :

générateur des mots de passe [XL-2010]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    DATAMINER
    Inscrit en
    Novembre 2014
    Messages
    147
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : DATAMINER
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Novembre 2014
    Messages : 147
    Par défaut générateur des mots de passe
    Bonjour,

    Je suis en train de cherche sur es forum pour crée un générateur de mot de passe vu un besoin sur mon boulot
    Pour le moment j’ai bien réussi a mettre un code vba « fonction » qui permet de faire ce travail sauf j’ai besoin d’automatisé la tache
    Comme un menu qui me permet :

    1- choisir le nombre de caractère a mettre dans le mot de passe
    2- combien de chiffre je souhaite avoir dans le mot de passe
    3- combien de symbole je souhaite avoir dans le mot de passe
    4- combien de mot de passe a généré

    je partage avec vous le code ci-dessous :

    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
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    ' Déclaration des variables obligatoire '
    Option Explicit
     
    ' ---------------------------------------------------------------------------------------------------- '
    ' Fonction personnalisée permettant de générer des mots de passe contenant des lettres et, en option, chiffres et symboles. '
    ' Tous les arguments sont facultatifs. Par défaut, la longueur du mot de passe est de 8 caractères. '
    ' =MOTDEPASSE(10;2;1) permet de créer un mot de passe contenant 10 caractères, dont 2 chiffres et 1 symbole. '
    ' '
    ' Auteur : Philippe Enderlin <http://www.enderlinphilippe.fr> '
    ' ---------------------------------------------------------------------------------------------------- '
    Function MOTDEPASSE(Optional Longueur As Long = 8, Optional Nbre_chiffres As Integer = 0, Optional Nbre_symboles As Integer = 0) As String
     
    ' Déclaration des constantes '
    ' On limite à 10 le nombre maximal de chiffres et de symboles '
    Const maxChiffres = 10
    Const maxSymboles = 10
     
    ' Déclaration des variables '
    Dim i, j, n, debut, fin As Long
    Dim strLettres, strChiffres, strSymboles, strChaine, strMot As String
    Dim varTab, varTemp As Variant
     
    ' Chaînes de caractères contentant lettres, chiffres et symboles '
    strLettres = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"
    strChiffres = "0123456789"
    strSymboles = "@#&§%$£€(){}[]\`~_<>=+-*/!?;.:"
    strChaine = strLettres & strChiffres & strSymboles
     
    ' On limite le nombre total de chiffres '
    If Nbre_chiffres > maxChiffres Then
        Nbre_chiffres = maxChiffres
    ' On limite le nombre total de chiffres à la longueur du mot de passe '
    ElseIf Nbre_chiffres > Longueur Then
        Nbre_chiffres = Longueur
    End If
     
    If (Nbre_symboles + Nbre_chiffres) > Longueur Then
        Nbre_symboles = Longueur - Nbre_chiffres
    ' On limite le nombre total de symboles '
    ElseIf Nbre_symboles > maxSymboles Then
        Nbre_symboles = maxSymboles
    ' On limite le nombre total de symboles à la longueur du mot de passe '
    ElseIf Nbre_symboles > Longueur Then
        Nbre_symboles = Longueur
    End If
     
    ' On redéfinit la taille du tableau en fonction de la longueur du mot de passe '
    ReDim varTab(Longueur)
     
    ' Si l’argument Nbre_chiffres est renseigné '
    If Nbre_chiffres > 0 Then
        ' On détermine les positions de début et de fin de la chaîne '
        debut = CLng(Len(strLettres) + 1)
        fin = CLng(debut + Len(strChiffres) - 1)
        ' Boucle permettant de stocker les chiffres dans un tableau '
        For i = 1 To Nbre_chiffres
            varTab(i) = Mid(strChaine, (Rnd() * (fin - debut) + debut), 1)
        Next i
    End If
     
    ' Si l’argument Nbre_symboles est renseigné '
    If Nbre_symboles > 0 Then
        ' On détermine les positions de début et de fin de chaîne '
        debut = CLng(Len(strLettres + strChiffres) + 1)
        fin = CLng(debut + Len(strSymboles) - 1)
        ' Boucle permettant de stocker les symboles dans un tableau '
        For i = 1 To Nbre_symboles
            varTab(CLng(i + Nbre_chiffres)) = Mid(strChaine, (Rnd() * (fin - debut) + debut), 1)
        Next i
    End If
     
    ' Si la longueur du mot de passe est supérieure au nombre de chiffres et symboles '
    If (Longueur > (Nbre_symboles + Nbre_chiffres)) Then
        ' Boucle permettant de stocker les lettres dans un tableau '
        For i = 1 To (Longueur - (Nbre_symboles + Nbre_chiffres))
            varTab(CLng(i + Nbre_chiffres + Nbre_symboles)) = Mid(strChaine, (Rnd() * (Len(strLettres) - 1) + 1), 1)
        Next i
    End If
     
    ' Tri aléatoire du tableau contenant lettres, chiffres et symboles '
    Randomize
    For n = LBound(varTab) To UBound(varTab)
        j = CLng(((UBound(varTab) - n) * Rnd) + n)
        If n <> j Then
            varTemp = varTab(n)
            varTab(n) = varTab(j)
            varTab(j) = varTemp
        End If
    Next n
     
    ' Reconstitution du mot de passe après tri aléatoire '
    For i = LBound(varTab) To UBound(varTab)
        strMot = strMot & varTab(i)
    Next i
     
    ' On renvoie le mot de passe '
    MOTDEPASSE = strMot
     
    End Function
    merci d’avance de votre aide je suis novice en VBA

    Cdt,

  2. #2
    Membre confirmé
    Homme Profil pro
    DATAMINER
    Inscrit en
    Novembre 2014
    Messages
    147
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : DATAMINER
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Novembre 2014
    Messages : 147
    Par défaut
    Bonjour,

    Je partage avec mon aidé que j’ai créé sur un userform

    Nom : Générateur.png
Affichages : 2604
Taille : 180,8 Ko

    et les résultats soit directement sur la 1er colonne

    Cdt,

  3. #3
    Inactif  

    Homme Profil pro
    cuisiniste
    Inscrit en
    Avril 2009
    Messages
    15 374
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : cuisiniste
    Secteur : Bâtiment

    Informations forums :
    Inscription : Avril 2009
    Messages : 15 374
    Billets dans le blog
    8
    Par défaut heu
    Bonjour
    j'ai trouver la question interessante

    alors voila je n'avais vu que ton premier post alors j'ai fait cet exemple

    je n'ai pas pris soin de lui faire du tunning il va a l'essentiel

    alors dans le userform tu a 4 textBOX UN LABEL DEVANT CHACUN T'INDIQUE A QUOI IL SERVENT

    dans la sub du bouton tu a une boucle qui boucle sur la valeur de NBMP( nombre de mots de passe

    dans cette boucle tu a 3 boucle sur la valeur des 3 autre textbox(nombre de caracteres,nombre de chiffre,nombre de symbols)

    chaque boucle choisi autant de (carateres /chiffre/symbols) que dans leur textbox respectif

    exemple si javais mis dans le userform
    3
    5
    5
    1

    je demanderais donc 1 mot de passe de 3 caractere de l'alphabet avec 5 chiffre de 0 a 9 et enfin 5 symbole

    j'obtiens donc EXEMPLE

    bPH61734<§°~]

    MAINTENANT APRES CES 3 BOUCLES IL Y EN A UNE DERNIERE QUI VA FOUTRE LE BOXON DANS L'ORDRE DE LA CHAINE OBTENUE

    on pourrait obtenir exemple
    b§H6°1~7P4<]3

    les résultat sont memorisés dans une variable tableau que je transpose dans la lmistebox de droite

    tu peut tres bien transposer le tablo dans le sheets

    exemple
    sheets(1).cells(1,1).resize(ubound(tablo),1)=tablo
    voila je te laisse analyser tout ca

    c'est assez rigolo des fois le résultat


    demo en image et fichier en piece jointe
    Nom : Capture.JPG
Affichages : 2473
Taille : 228,9 Ko

    ca devrait répondre a ta question

    Fichiers attachés Fichiers attachés
    mes fichiers dans les contributions:
    mail avec CDO en vba et mail avec CDO en vbs dans un HTA
    survol des bouton dans userform
    prendre un cliché d'un range

    si ton problème est résolu n'oublie pas de pointer : : ça peut servir aux autres
    et n'oublie pas de voter

  4. #4
    Membre confirmé
    Homme Profil pro
    DATAMINER
    Inscrit en
    Novembre 2014
    Messages
    147
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : DATAMINER
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Novembre 2014
    Messages : 147
    Par défaut
    Merci bcq pour l’effort, sauf que j’ai une petite remarque
    Quand j’ai besoin d’un mot de passe sans symbole je laisse le chiffre zéro mais lui il accepte pas ou par exemple quand je taper 6 caractères et 2 chiffres et je laisse la case symbole vide et le nombre des mots de passe 5
    Le 1er mot de passe que j’ai il respecte les conditions mais juste après je pars pour avoir des mots de passe à 10 caractère dans le tous
    tu peux mémé vérifier sur l'exemple image que tu es envoyé dans la totalité ta demande 15 caractères mais sur les résultats le 1er mot de passe à 15 cataractes mais les autres passe a 16 et mémé plus.

  5. #5
    Inactif  

    Homme Profil pro
    cuisiniste
    Inscrit en
    Avril 2009
    Messages
    15 374
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : cuisiniste
    Secteur : Bâtiment

    Informations forums :
    Inscription : Avril 2009
    Messages : 15 374
    Billets dans le blog
    8
    Par défaut re
    bonjour
    t dur en affaire hein !!!

    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
    Private Sub CommandButton1_Click()
        Dim tablo, chaine As String, chaineF As String, m As Long, c As Long, ch As Long, S As Long
        strLettres = Split(StrConv("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ", vbUnicode), Chr(0))
        strChiffres = Split(StrConv("0123456789", vbUnicode), Chr(0))
        strSymboles = Split(StrConv("@#&§%$£€(){}[]\`~_<>=+-*/!?;.:", vbUnicode), Chr(0))
        Randomize
        ReDim tablo(Val(NBMP), 1)
        'If NBCA = 0 Or NBCH = 0 Or NBS = 0 Or NBMP = 0 Then MsgBox "vous n'avez pas rempli tout les criteres demandés": Exit Sub
        For m = 1 To Val(NBMP)
            chaine = ""
            'on récupère dans la variable chaine le nombre de caractere au hazard dans les 52 possibilités des lettres
            If NBCA.Value > 0 Then For c = 0 To Val(NBCA): Randomize: chaine = chaine & strLettres(Rnd * UBound(strLettres)): Next
            'on ajoute  dans la variable chaine le nombre de chiffres au hazard dans les 9 possibilités des chiffres
           If NBCH.Value > 0 Then For ch = 0 To Val(NBCH): Randomize: chaine = chaine & strChiffres(Rnd * UBound(strChiffres)): Next
            'on ajoute  dans la variable chaine le nombre de symboles  au hazard dans les  possibilités des chiffres
            If NBS.Value > 0 Then For S = 0 To Val(NBS): Randomize: chaine = chaine & strSymboles(Rnd * UBound(strSymboles)): Next
     
            'a partir de la on a une chaine caracterenombresymbole
            'maintenant pour le fun on va remuer le tout
            chaineF = "": compte = 0
            For i = 1 To 250
                ind = Round(Rnd * Len(chaine)): If ind = 0 Then ind = 1
                lettre = Mid(chaine, ind, 1)
                If InStr(chaineF, lettre) <= 0 Then
     
                   chaineF = chaineF & lettre
                Else
                End If
     
            Next
            tablo(m - 1, 0) = chaineF
        Next
        ListBox1.List() = tablo
    End Sub
    mes fichiers dans les contributions:
    mail avec CDO en vba et mail avec CDO en vbs dans un HTA
    survol des bouton dans userform
    prendre un cliché d'un range

    si ton problème est résolu n'oublie pas de pointer : : ça peut servir aux autres
    et n'oublie pas de voter

  6. #6
    Membre confirmé
    Homme Profil pro
    DATAMINER
    Inscrit en
    Novembre 2014
    Messages
    147
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : DATAMINER
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Novembre 2014
    Messages : 147
    Par défaut
    je vois toujours la même problématique je suis en train de voir si il y a un changement a mettre dans le code pour limité les résultats selon la demande
    j'ai remarque que le code et généreux il donne plus que ta demande

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

Discussions similaires

  1. fichier des mots de passe
    Par Isabella dans le forum Oracle
    Réponses: 6
    Dernier message: 25/02/2006, 08h52
  2. Sauvegarde des Mots de passe de connexion Web
    Par zakuli dans le forum Windows XP
    Réponses: 5
    Dernier message: 08/12/2005, 19h05
  3. Générateur de mot de passe
    Par christel1982 dans le forum ASP
    Réponses: 2
    Dernier message: 16/11/2005, 12h25
  4. enregistrer et masquer des mots de passe
    Par champion dans le forum PostgreSQL
    Réponses: 2
    Dernier message: 30/08/2004, 20h10
  5. Au sujet des mots de passe
    Par FranT dans le forum Langage
    Réponses: 6
    Dernier message: 17/09/2002, 22h16

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