Code-Beispiel

Anlegen eines Benutzers mit dem WinNT-Provider

Ein Beispiel zum Einsatz der Klasse System.DirectoryServices.DirectoryEntry aus der .NET-Klassenbibliothek.

Autor: Dr. Holger Schwichtenberg

Beschreibung

Das Anlegen eines Benutzers mit dem WinNT-Provider ist dem Anlegen eines Benutzers mit dem LDAP-Provider sehr ähnlich. Allerdings gibt es keine Pflichtattribute, die zu setzen sind. Das Löschen ist völlig analog und kann daher mit der allgemeinen Hilfsroutine ADSILoeschen_Rekursiv("BenutzerDN") erfolgen.

Programmcodebeispiel in Visual Basic .NET (VB.NET)

' --- Demo-Daten für WINNT-Provider
Const COMPUTER = "mars"
Const BENUTZER = "HSch"

' ============================
' .NET-Code-Beispiel in Visual Basic .NET
' Anlegen eines Benutzers mit dem WinNT-Provider
' (C) Holger@Schwichtenberg.de
' ============================
Sub WINNT_Benutzeranlegen()

Dim o As DirectoryEntry
Dim c As DirectoryEntries

Dim Benutzer_DN As String

Benutzer_DN = "WinNT://" & COMPUTER & "/" & BENUTZER

outtitle("Benutzer anlegen:" & Benutzer_DN)

' -- Prüfung, ob Objekt vorhanden ist
If DirectoryEntry.Exists(Benutzer_DN) Then
out("Benutzer bereits vorhanden...")
ADSILoeschen_Rekursiv(BenutzerDN)
End If

' --- Zugriff auf IADs
o = New DirectoryEntry("WinNT://" & COMPUTER)
' --- Zugriff auf IADsContainer
c = o.Children()
' --- Neues Objekt erzeugen
o = c.Add(BENUTZER, "user")
' --- Verzeichnisattribute festlegen
o.Invoke("setpassword", "123456789")
o.CommitChanges()

o.NativeObject.AccountDisabled = False
o.CommitChanges()

out("Benutzer angelegt!")

End Sub

Weiteres Programmcodebeispiel in CSharp (C#)

using System;
using System.Collections;
using System.DirectoryServices;

namespace FCLBuch._SystemDirectoryServices {

public class SamplesADSIWINNT {
public void WINNT_Benutzeranlegen() {

// Anlegen eines Benutzers mit dem WinNT-Provider
string Benutzer_DN = "WinNT://" + COMPUTER + "/" + BENUTZER;

FclOutput.PrintOutSubHeader("Benutzer anlegen:" + Benutzer_DN);

// Prüfung, ob Objekt vorhanden ist
if (DirectoryEntry.Exists(Benutzer_DN)) {
FclOutput.PrintOut("Benutzer bereits vorhanden...");
ADSIHelperMethods.ADSI_Loeschen_Rekursiv(BenutzerDN);
}

// Zugriff auf IADs
DirectoryEntry o = new DirectoryEntry("WinNT://" + COMPUTER);
// Zugriff auf IADsContainer
DirectoryEntries c = o.Children;
// Neues Objekt erzeugen
o = c.Add(BENUTZER, "user");
// Verzeichnisattribute festlegen
o.Invoke("setpassword", "123456789");
o.CommitChanges();

((ActiveDs.IADsUser)o.NativeObject).AccountDisabled = false;
o.CommitChanges();

FclOutput.PrintOut("Benutzer angelegt!");
}
}
}

Hinweise

Ausgaben werden in den Beispielen durch Hilfsroutinen wie out() und PrintOut() erzeugt. Diese sind hier nicht angegeben, da deren Implementierung von der jeweiligen Umgebung abhängt. Für Konsolenanwendungen können hier z.B. Console.WriteLine() einsetzen.


 

Querverweise

 Liste aller Codebeispiele  Definition '.NET Framework Class Library'  Verfügbarkeit der Klasse 'System.DirectoryServices.DirectoryEntry'  Übersicht über den FCL-Namensraum 'System.DirectoryServices'  .NET & Visual Studio Community Portal

Buchtipp

Buchcover PowerShell 7 und Windows PowerShell 5 – das Praxishandbuch (6. Auflage Juni 2024 (10. Auflage Gesamtreihe)) PowerShell 7 und Windows PowerShell 5 – das Praxishandbuch
Autor(en): Dr. Holger Schwichtenberg
Erschienen 2024
Umfang: 1426 Seiten
ISBN: 3446481958

Beratung & Support

Schulungen

  Anfrage für eine individuelle Schulung zum Thema VISUAL BASIC C#   Gesamter Schulungsthemenkatalog

Fachbücher

  Alle unsere aktuellen Fachbücher   E-Book-Abo für ab 99 Euro im Jahr