Windows Azure Cloud Storage ermöglicht es Ihnen bereits ab 0,10€ pro GB/Monat die Vorteile der Cloud zu nutzen.
Willkommen bei dotnet-snippets.de! Snippet hinzufügen Login Registrieren
Snippets in der Datenbank: 1551 | Anzahl registrierter User: 1841 | Besucher online: 195
Hauptmenü
Home
Top Ten
Zufälliger Snippet
FAQs
.NET Community
dotnet-forum.de
dotnet-kicks.de
Social

RSS Feeds
Rss Alle Snippets
Rss C#
Rss VB.NET
Rss C++
Rss ASP.NET
Partner
Member of Microsoft Community Leader/Insider Program (CLIP)

Auf Mitgliedschaft einer Windows-Sicherheitsgruppe prüfen


Autor: Rainbird
Sprache: C#
Bewertung:
6.71 (5 votes)
Anzahl der Aufrufe: 8349
  
Kick it on dotnet-kicks.de  

Beschreibung:

Dieses Snippet überprüft, ob der aktuelle Benutzer Mitglied einer bestimmten Windows-Sicherheitsgruppe ist. Es spielt dabei keine Rolle, ob es sich um eine lokale, oder eine Active Directory-Gruppe handelt.
Eine solche Prüfung ist z.B. sehr nützlich, wenn eine Methode nur von Mitgliedern der Gruppe "CompanyXY\Geschäftsleitung" ausgeführt werden darf. Man müsste schon das Windows-Sicherheitssystem umgehen, um an dieser Prüfung vorbeizukommen.


Abgelegt unter: Security, Sicherheit, Windows-Sicherheit, Identity, Windows-gruppe, Security-Group, Active Directory, Rollenprüfung.



C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
/// <summary>
/// Prüft, ob der aktuelle Windows-Benutzer Mitglied in einer bestimmten Windows-Sicherheitsgruppe ist.
/// </summary>
/// <param name="groupName">Name der Windows-Sicherheitsgruppe (Format: "Domain\Group")</param>
/// <returns>Wahr, wenn der benutzer Mitglied der Gruppe ist, ansonsten Falsch</returns>
public static bool IsCurrentUserInWindowsGroup(string groupName)
{
    // Aktuellen Windows-Benutzer ermitteln
    System.Security.Principal.WindowsIdentity identity = System.Security.Principal.WindowsIdentity.GetCurrent();

    // Wenn der Benutzer nicht authentifiziert ist ...
    if (!identity.IsAuthenticated)
        // Sicherheits-Ausnahme werfen
        throw new System.Security.SecurityException("Benutzer wurde nicht ordnungsgemäß authentifiziert.");

    // Prinzipal-Objekt zur Sicherheitsprüfung des Windows-Benutzers erzeugen
    System.Security.Principal.WindowsPrincipal principal = new System.Security.Principal.WindowsPrincipal(identity);

    // Wahr zurückgeben, wenn der Benutzer Mitglied in der angegebenen Sicherheitsgruppe ist, ansonsten Falsch.
    return principal.IsInRole(groupName);
}
Sie haben Fragen zu diesem Snippet oder brauchen Hilfe bei der .NET Entwicklung?
Freundliche und kompetente Entwickler helfen Ihnen gern weiter im Forum für .NET Entwicklung.



Kommentare:
(Zum Schreiben von Kommentaren bitte anmelden.)



schlecht sehr gut
1 2 3 4 5 6 7 8 9 10
Nur angemeldete User können Snippets bewerten.