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

VBScript Discussion :

Lister les répertoires réseaux et les droits


Sujet :

VBScript

  1. #1
    Invité
    Invité(e)
    Par défaut Lister les répertoires réseaux et les droits
    Bonjour j'essai de combiner 2 scripts qui permettraient de lister les répertoire réseaux d'un utilisateur ainsi que les droits associés à ce répertoire...

    J'ai la première partie que se fait bien mais la seconde de lister les droits...ça ne fonctionne pas?

    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
    scriptVersion = "1.0"
     
    Set objShell = CreateObject("WScript.shell")
    Set objEnv = objShell.Environment("Process")
    Set objFSO = CreateObject("Scripting.FileSystemObject")
    Set objNetwork = CreateObject("WScript.Network")
     
    strUserName = objEnv("USERNAME")
    strComputerName = lcase(objEnv("COMPUTERNAME"))
    bPath = "\\127.0.0.1\listing"    ' Server and path to save files
    bFile =  bPath & "\" & strComputerName &"-" & strUserName & "-NetDrives.txt"
     
    'Setup output file
    If objFSO.FileExists(bFile) then
        Set objTextFile = objFSO.OpenTextFile(bFile, 8, True)   ' 8 = appending
    Else
        Set objTextFile = objFSO.OpenTextFile(bFile, 2, True)   ' 2 = writing
    End if
     
    objTextFile.WriteLine Now & " ::: Drive mappings listing v" & scriptVersion
     
    'Loop through current network drives
    Set colDrives = objNetwork.EnumNetworkDrives
    For i = 0 to colDrives.Count-1 Step 2
     objTextFile.WriteLine colDrives.Item(i) & vbTab & colDrives.Item (i + 1)
     'Cette partie de code à modifier pour les droits-----------------------------
     arrComputers = Array(".")
    For Each strComputer In arrComputers
            Set objWMI = GetObject("winmgmts:\\" & strComputer & "\root\cimv2") 
            Set colACLs = objWMI.ExecQuery("Select * from win32_share")
            For Each share In colACLs 
                    strDir = share.path 
                    strWrite = "SHARE NAME] " & ucase(Share.name)
     
                    strDir = Replace(strDir,"\","\\") 
                    Set colACLs = objWMI.ExecQuery("Select * from win32_logicalFileSecuritySetting WHERE Path='" & strDir & "'",,48)
                    for each objItem in colACLs
       If objItem.GetSecurityDescriptor(objSD) Then
        DisplayFileSecurity = False
       End If
     
                            For each objAccessList in objSD.DACL 
                                    strAccessList = objAccessList.Trustee.Domain & "\" & objAccessList.Trustee.Name 
                                    if left(strAccessList,1) = "\" then
         strAccessList = right(strAccessList,len(strAccessList) -1)
        end if  
     
        prevWrite = strWrite                              
        strWrite = "GROUP] " & Ucase(strAccessList)
     
        if prevWrite <> strWrite and strWrite <> "GROUP] " then 
         objTextFile.WriteLine ucase(strWrite) 
    	 objTextFile.WriteLine strNewText
                                    end if                         
       Next 
                    Next 
            Next 
    Next
    'fin---------------------------------------------------------------
    Next
     
    Set objShell = Nothing
    Set objFSO = Nothing
    Set objNetwork = Nothing
     
    Wscript.Quit(ExitErrorLevel)
    Dans le code j'ai associé les 2 codes mais logiquement ça ne fonctionne pas...que dois je modifier pour me permettre l'opération.

    lignes 26 a 59 est a modifier pour s'associer au reste du code?

    Merci

  2. #2
    Modérateur
    Avatar de l_autodidacte
    Homme Profil pro
    Retraité : Directeur de lycée/Professeur de sciences physiques
    Inscrit en
    Juillet 2009
    Messages
    2 415
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 68
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Retraité : Directeur de lycée/Professeur de sciences physiques
    Secteur : Enseignement

    Informations forums :
    Inscription : Juillet 2009
    Messages : 2 415
    Points : 5 806
    Points
    5 806
    Par défaut
    Salut;

    Ton code est très mal indenté donc presque illisible.
    Tu utilises la variable colACLs pour définir un objet bien déterminé et tu l'utilises dans une boucle. Dans la même boucle tu la réutilises pour définir un autre objet totalement différent(Ligne 30 et ligne 36).
    Dans ce cas le traitement se fait sur quel objet ? le premier ou le le second ??? le premier étant écrasé par le second.
    Je vois là un mélange insoluble !!

    Essaie donc de donner un autre nom à la variable(lignes 36 et 37) colACLs1 par exemple pour enlever l’ambiguïté.
    Ne pas oublier le tag si satisfait.
    Voter pour toute réponse satisfaisante avec pour encourager les intervenants.
    Balises CODE indispensables. Regardez ICI
    Toujours utiliser la clause Option Explicit(VBx, VBS ou VBA) et Ne jamais typer variables et/ou fonctions en VBS.
    Vous pouvez consulter mes contributions
    Ne pas oublier de consulter les différentes FAQs et les Cours/Tutoriels VB6/VBScript
    Ne pas oublier L'Aide VBScript et MSDN VB6 Fr

Discussions similaires

  1. [Batch] lister un répertoire , en excluant les sous répertoires
    Par vince2005 dans le forum Scripts/Batch
    Réponses: 2
    Dernier message: 23/05/2015, 21h53
  2. Lister les disques durs USB, les clés ainsi que les appareils photos
    Par infosam76 dans le forum VB 6 et antérieur
    Réponses: 17
    Dernier message: 25/02/2015, 23h26
  3. [Batch] Connexion SFTP + download de tous les fichiers ET tous les répertoires
    Par gazza dans le forum Scripts/Batch
    Réponses: 2
    Dernier message: 06/03/2014, 13h45
  4. [IPv4] Une question sur les IPs, les sous-réseaux et les masques
    Par Bahan_auboulot dans le forum Développement
    Réponses: 2
    Dernier message: 27/11/2008, 14h21
  5. Les moteurs réseaux pour les jeux
    Par johnvx dans le forum Développement
    Réponses: 4
    Dernier message: 18/03/2008, 15h22

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