Veröffentlicht 2. Juli 200817 j Hallo an alle, ich möchte bei allen Usern einer OU im Active Directory das Attribut "userWorkstations" ändern und einen Computer hinzufügen, an dem sich die Anwender anmelden können. Ich habe dazu ein VB-Skript gefunden, wo ich das für einen einzelnen Useraccount machen kann: Set objUser = GetObject _ ("LDAP://cn=Ken Myer,ou=Finance,dc=fabrikam,dc=com") objUser.Put "userWorkstations", "atl-ws-01,atl-ws-02,atl-ws-03" objUser.SetInfo Kann mir jemand helfen, das für eine gesamte OU umzusetzen? (Wird doch wahrscheinlich irgendwie mit einer FOR Schleife geregelt?!)
3. Juli 200817 j Ich hab da mal vor einiger Zeit was gescripted...Den relevanten teil hab ich dir mal rausgesucht... *g*: Set Exchange_Query = GetObject("LDAP://ou=Finance,dc=fabrikam,dc=com") 'Alle einträge werden ausgegeben For Each Ex_User In Exchange_Query <dein Skript> Next MfG Erratum
4. Juli 200817 j also, ich habe nun folgendes Skript zusammen gebastelt: Option Explicit Dim objContainer Const ADS_PROPERTY_APPEND = 3 Set objContainer=GetObject("LDAP://OU=Template Users,OU=Users,OU=companyname,DC=domain,DC=local") ModifyUsers objContainer 'cleanup Set objContainer = Nothing WScript.Echo "Finished" Sub ModifyUsers(ByRef objContainer) Dim objUser objContainer.Filter = Array("user") For Each objUser in objContainer objUser.PutEx ADS_PROPERTY_APPEND, "userWorkstations", Array("test") objUser.SetInfo Next End Sub Diese Skript funktioniert auch, aber es ersetzt mir die bereits vorhandenen Werte. Ich möchte aber einen Computernamen hinzufügen zu den bereits bestehenden. Ich habe gelesen, dass die PutEx Methode mit der ADS_PROPERTY_APPEND Variable Werte zu einem Multivalue Feld hinzufügt. Ich weiß aber nicht genau, ob das Attribut "userWorkstations" ein solches Multivalue Feld ist. Hat jemand eine Idee?
7. Juli 200817 j Ich weiß aber nicht genau, ob das Attribut "userWorkstations" ein solches Multivalue Feld ist. Contains the NetBIOS or DNS names of the computers running Windows NT Workstation/Windows 2000 Professional from which the user can log on. Each NetBIOS name is separated by a comma. The NetBIOS name of a computer is the saMAccountName property of a computer object. Multiple names should be separated by commas. s'Amstel
7. Juli 200817 j Ja diese Info habe ich auch gelesen. Leider behebt das nicht mein Problem, denn mein gepostetes Skript ersetzt alle bestehenden Einträge! Ich möchte aber einen neuen hinzufügen!
8. Juli 200817 j Ich bin heute noch auf etwas gestoßen! Das Attribut "userWorkstations" scheint KEIN Multivalued Feld zu sein. Auf den MSDN Seiten, wo das Attribut beschrieben ist, wird nämlich folgende Eigenschaft genannt: Is-Single-Valued: True (User-Workstations Attribute (Windows)) Dann ist es wahrscheinlich nicht möglich, einen neuen Wert zu den bereits bestehenden hinzuzufügen. Ich werde nun versuchen als erstes die bestehenden Werte auszulesen und diese dann mit den neuen erneut in das Atrribut zu schreiben.
16. Juli 200817 j Hi Leute, also ich habe nun eine für mich akzeptable Lösung gefunden! Ich lese erst die bestehenden Computernamen des Feldes aus und füge diese und den neuen Computernamen dem Attribut hinzu. Anbei mein Skript: Option Explicit Dim objContainer Const ADS_PROPERTY_APPEND = 3 Set objContainer=GetObject("LDAP://OU=MyUsers,DC=domain,DC=local") ModifyUsers objContainer 'cleanup Set objContainer = Nothing WScript.Echo "Finished" Private Function ModifyUsers(ByVal objContainer) Dim objUser, strWSbefore objContainer.Filter = Array("user") For Each objUser in objContainer strWSbefore = objUser.userWorkstations objUser.Put "userWorkstations", strWSbefore & ",computer2" objUser.SetInfo Next End Function Danke für die Unterstützung.
Archiv
Dieses Thema wurde archiviert und kann nicht mehr beantwortet werden.