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 :

Modification nom des machines dans l'AD.


Sujet :

VBScript

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    172
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 172
    Par défaut Modification nom des machines dans l'AD.
    Bonjour,

    J'ai un parc d'environ 800 postes, et mon entreprise me demande de renommer toutes les machines du parc pour une question d’harmonisation.

    N'ayant pas envie de passer sur chaque machine et de modifier manuellement le compte d'ordinateur sur l'AD, je me suis dis qu'un script vbs s'exécutant sur l'ouverture de session des utilisateurs serait super...

    Cependant n'étant pas un spécialiste en vbs je voudrai avoir votre avis sur la question.

    Je voudrai que mon script renomme la machine et mette à jour l'AD en même temps. Est ce que vous pensez que c'est possible ?

    Et si oui avez vous des liens pouvant m'expliquez comment procéder ?

    Merci.

  2. #2
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    172
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 172
    Par défaut
    Rebonjour,

    J'ai réussi à faire mon script, il fonctionne très bien quand on se log avec un compte ayant les droits administrateur sur l'AD, par contre si un utilisateur lambda se connecte, le script ne fonctionne pas.

    Comment est-il possible de lancer le script avec les droits nécessaire à l'utilisateur pour modifier l'AD ?

    Merci.

  3. #3
    Expert confirmé
    Avatar de hackoofr
    Homme Profil pro
    Enseignant
    Inscrit en
    Juin 2009
    Messages
    3 843
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Juin 2009
    Messages : 3 843
    Par défaut
    Citation Envoyé par fred61 Voir le message
    Rebonjour,
    J'ai réussi à faire mon script, il fonctionne très bien quand on se log avec un compte ayant les droits administrateur sur l'AD, par contre si un utilisateur lambda se connecte, le script ne fonctionne pas.
    Comment est-il possible de lancer le script avec les droits nécessaire à l'utilisateur pour modifier l'AD ?
    Merci.

    montre nous votre code après avoir supprimer vos infos personnels ou bien les infos de votre entreprise.

  4. #4
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    172
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 172
    Par défaut
    Voilà ou j'en suis, j'ai essayé de faire 2 scripts, le premier run.vbs qui est lancé par la GPO, exécute un lsrunas avec les droits admin sur le 2° script :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Set wshell = WScript.CreateObject("WScript.Shell")
    Return = wshell.run ("lsrunas /user:admin_dom /password:****** /domain:monDom /command:""wscript.exe \\monDom\SysVol\monDom\Policies\{D11C77ED-4F9C-4C8D-8770-xxxxxxxxxx}\User\Scripts\Logon\chg_nom_machine.vbs"" /runpath:.\", 1, true)
    Et voici le script chg_nom_machine.vbs lancé par le code précédent :

    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
    Dim RegKeyCompName, RegKeyTCPIP, WSHShell, ComputerName, HostName, DomainName, FQDN, ADRootDSE, ADSysInfo, ADComputerName, ADRenameOK, ADRNewName, vStartRenameCA, NewNAmeU, NewNameL, vStartRenameAD
     
    On Error Resume Next
     
    'Definition du nouveau nom de la machine = UC + adresse MAC
    strComputer = "."
    Set objWMIService = GetObject("winmgmts:" _
    & "{impersonationLevel=impersonate}!\\" & strComputer & "\root\cimv2")
    dim mac
    dim NouveauNom  'Nouveau nom ?d閒inir
    Set IPConfigSet = objWMIService.ExecQuery _
    ("Select * from Win32_NetworkAdapterConfiguration Where IPEnabled=TRUE") 
     
    For Each IPConfig in IPConfigSet 
    If Not IsNull(IPConfig.IPAddress) Then 
    For i=LBound(IPConfig.IPAddress) to UBound(IPConfig.IPAddress) 
    mac = IPConfig.MACAddress(i)
    Next 
    End If
    Next
     
    'MsgBox mac
    NouveauNom = "UC" & Replace(mac,":","")
    'MsgBox NouveauNom
     
     
     
    '###### Recuperation des infos sur le PC local ######
    RegKeyCompName = "HKLM\SYSTEM\CurrentControlSet\Control\ComputerName\"
    RegKeyTCPIP = "HKLM\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters\"
     
    Set WSHShell = CreateObject("WScript.Shell")
     
    ComputerName = WSHShell.RegRead (RegKeyCompName & "ComputerName\ComputerName")
    Hostname = WSHShell.RegRead (RegKeyTCPIP & "Hostname")
    DomainName = WSHShell.RegRead (RegKeyTCPIP & "Domain")
    FQDN = HostName & "." & DomainName
     
    Set ADRootDSE = GetObject("LDAP://RootDSE")
    If Err.Number <> 0 then
        ADComputerName = "Unable to determine this information"
        ADOU = "Unable to determine this information"
        ADRenameOK = "0"
    else
        Set ADSysInfo = CreateObject("ADSystemInfo")
        ADComputerName = ADSysInfo.ComputerName                'Recup DN de l'ordinateur local
        ADRenameOK = "1"
        ADOU = Mid(ADComputerName, InStr(ADComputerName, "=") + 1)
        ADOU = Mid(ADOU, InStr(ADOU, "=") - 2)
        ComputerPath = "LDAP://" & ADComputerName
        OUPath = "LDAP://" & ADOU
    End if
     
     
     
    '###### MODIFICATION DU NOM DE L'ORDINATEUR EN LOCAL ET SUR L'AD ###########
    NewName = NouveauNom
    NewNameU = UCase(NewName)
    NewNameL = LCase(NewName)
    NewNameUCN = "CN=" & NewNameU
     
    if NewName = "" then
        wscript.echo "Le nom de l'ordinateur n'a pas pu etre change!"
    else
            'Modification dans la base de registre
            With WSHShell
                .RegDelete RegKeyTCPIP & "Hostname"
                .RegDelete RegKeyTCPIP & "NV Hostname"
                .RegWrite RegKeyCompName & "ComputerName\ComputerName", NewNameU
                .RegWrite RegKeyCompName & "ActiveComputerName\ComputerName", NewNameU
                .RegWrite RegKeyTCPIP & "Hostname", NewNameL
                .RegWrite RegKeyTCPIP & "NV Hostname", NewNameL
            End With
     
            'Modification dans l'AD
            if ADRenameOK = 1 then
                Set objItem = GetObject(ComputerPath)
                objItem.Put "dNSHostName", NewNameL & "." & DomainName
                objItem.SetInfo
                objItem.Put "displayName", "DESKTOP_" & NewNameU & "$"
                objItem.SetInfo
                objItem.Put "sAMAccountName", NewNameU & "$"
                objItem.SetInfo
     
                Set objNewOU = GetObject(OUPath)
                Set objMoveComputer = objNewOU.MoveHere _
                    (ComputerPath, NewNameUCN)
            else
                wscript.echo "Informations insuffisante pour renommer sur l'AD"
            End If
    End if

    Et pour l'instant ça fonctionne toujours bien avec lorsqu'un admin se log, mais pas un simple utilisateur du domaine, malgré le fait de faire un lsrunas avec un compte admin. Et je ne comprend pas pourquoi ???

Discussions similaires

  1. Modification du nom des noeud dans un XML
    Par Tchweizz dans le forum C#
    Réponses: 4
    Dernier message: 25/01/2014, 09h47
  2. IMPORTATION DES NOM DE MACHINE DANS L AD
    Par RYAN78 dans le forum Windows Serveur
    Réponses: 2
    Dernier message: 29/12/2008, 21h27
  3. Réponses: 13
    Dernier message: 03/05/2006, 13h15
  4. Cacher le nom des pages dans l'URL
    Par Prue dans le forum Balisage (X)HTML et validation W3C
    Réponses: 5
    Dernier message: 07/12/2005, 10h18
  5. MDI Application et nom des fenêtres dans le menu
    Par Captain_JS dans le forum C++Builder
    Réponses: 3
    Dernier message: 11/08/2005, 08h26

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