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 :

mot de passe [XL-2003]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Novembre 2009
    Messages
    322
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Novembre 2009
    Messages : 322
    Par défaut mot de passe
    Bonjour à nouveau.

    J'ai présentement un classeur en construction. Ce classeur sera utilisé par plusieurs personnes.

    Je ne désir pas donner la possibilité à certaines personnes de voir l'onglet des états financier de mon employeur par exemple.

    J'ai donc prévu une feuille de mon classeur avec les différents droits d'accès aux différents onglets du classeur et l'accès esr geré par un code vba.

    Ma question :

    Est-il possible qu'à l'ouverture du fichier qu'un userform s'affiche (à ce niveau je n'ai pas de problème) dans lequel il y aurait un combobox (je sais maintenant comment en faire grace à ce forum) qui aurait la liste de personne et un textbox qui, lors de la saisie du mot de passe de l'usager, prendrait la forme "¤¤¤¤¤¤¤¤¤¤" ou autres signes qui ne permet pas de voir ce qui est saisie.

    Bref un masque de saisie comme sur un réseau (usager/mot de passe)

    J'ai regardé ce tuto mais sans trouver ce que je veux.

    http://jeannot45.developpez.com/arti...ises/#LIII-C-3

  2. #2
    Membre chevronné
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    389
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 389
    Par défaut
    Bonjour,

    Pour un TextBox il existe la propriété PasswordChar qui devrait répondre à votre demande

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2009
    Messages
    89
    Détails du profil
    Informations personnelles :
    Âge : 64
    Localisation : France, Marne (Champagne Ardenne)

    Informations forums :
    Inscription : Août 2009
    Messages : 89
    Par défaut
    Bonjour

    Vous pouvez mettre différents onglets en xlSheetVeryHidden et ouvert avec une inputBox du genre :


    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
    Sub All_DeProtect_Dom()
    ' indiquer le mot de passe dans une inputBox pour déprotéger toutes les feuilles du classeur
        Dim feuil As Worksheet
        Dim DeProtect As Variant
        Application.ScreenUpdating = False
     
        DeProtect = InputBox(" Indiquer le mot de passe de protection", Title:="Déprotéger toutes les feuilles du classeur :")
        For Each feuil In ThisWorkbook.Worksheets   ' ou seulement le nom des onglets désirés
            feuil.Unprotect (DeProtect)
        Next
        Feuil1.Visible = xlSheetVisible
        Sheet4.Visible = xlSheetVisible
        Sheet6.Visible = xlSheetVisible
        Sheet69.Visible = xlSheetVisible
    End Sub
    et pour reprotéger:


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    Sub All_ReProtect_Dom()
    ' indiquer le mot de passe dans une inputBox pour reprotéger toutes les feuilles du classeur
        Dim feuil As Worksheet
        Dim ReProtect As Variant
     
       ReProtect = InputBox("Indiquer le mot de passe de protection", Title:="Reprotéger toutes les feuilles du classeur:")
        For Each feuil In ThisWorkbook.Worksheets
            feuil.Protect Password:=ReProtect
        Next
       Feuil1.Visible = xlSheetVeryHidden
       Sheet4.Visible = xlSheetHidden
       Sheet6.Visible = xlSheetVeryHidden
       Sheet69.Visible = xlSheetVeryHidden
    End Sub
    Pour reprotéger vous pouvez également utiliser Auto_Close pour être certains que les utilisateurs n'oublient pas de reprotéger les onglets sélectionnés

    Dom

  4. #4
    Invité
    Invité(e)
    Par défaut
    Bonjour

    Je suis désolé, mais cette protection sautera rapidement, il suffit de désactiver la macro au démarrage et on peut facilement rendre les feuilles visibles.

    Philippe

  5. #5
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Novembre 2009
    Messages
    322
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Novembre 2009
    Messages : 322
    Par défaut Mot de passe
    Merci à vous trois pour vos réponses et code.

    Je prends note du fait qu'il serait facile pour une personne ayant les connaissances pour faire sauter cette sécurité mais comme les gens pour qui le fichier est destiné ont encore de la dificulté à faire des simples sommes dans Excel, je peux dormir tranquille.

    Merci encore une fois.

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

Discussions similaires

  1. [phpMyAdmin] [phpMyAdmin] Problème mot de passe Root !
    Par StouffR dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 7
    Dernier message: 26/09/2014, 11h59
  2. [PostgresSQL]Pb accés des utilisateurs sans mot de passe
    Par woodwai dans le forum PostgreSQL
    Réponses: 2
    Dernier message: 22/05/2003, 16h06
  3. [VB6] [ADO] [Access] Changer le mot de passe
    Par dlpxlid dans le forum VB 6 et antérieur
    Réponses: 4
    Dernier message: 03/03/2003, 09h45
  4. Réccupération du mot de passe d'une connexion
    Par zinaif dans le forum Bases de données
    Réponses: 1
    Dernier message: 02/12/2002, 18h32
  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