Autor Beitrag
kleinerkutz
Hält's aus hier
Beiträge: 2



BeitragVerfasst: Do 01.04.10 14:15 
Hallo zusammen,

ich möchte gern alle Gruppen eines Benutzers im LDAP abfragen.
Wir haben hierzu 2 Anmeldeserver unter Linux.

Ich habe schon einige Snippets ausprobiert, allerdings liefern mir
alle Skripte nur eine Object mit dem Wert NULL zurück.

ausblenden volle Höhe C#-Quelltext
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:
private List<String> GetGroupsOfMember(string username)
{
    List<string> groups = new List<string>();
    // Objekt für AD-Abfrage erzeugen

    using (DirectorySearcher searcher = new DirectorySearcher(new DirectoryEntry(string.Empty)))
    {
        // nach Kriterium filtern - hier nach Gruppe mit einem best. Namen (Inhalt von 'username')
        searcher.Filter = string.Concat(string.Format(@"(&(ObjectClass=user)(sAMAccountName={0}))", username));

        // Anfrage mit gesetzteen Filter ausführen und Ergebnisse durch iterieren
        //foreach(SearchResult result in searcher.FindAll())
        foreach (SearchResult result in searcher.FindAll())
        {
            // Eigenschaft 'MemberOf' des AD-Knotenpunktes 'result' durch iterieren
            foreach (var group in result.Properties["MemberOf"])
            {
                // cast von 'group' zum Datentyp 'string' sollte nicht möglich sein, wird 'groupResult' 'null'
                string groupResult = group as string;

                if (groupResult != null)
                {
                    // CN aus dem Pfad extrahieren und zur Liste hinzufügen
                    groups.Add(groupResult.Substring(3, groupResult.IndexOf(',') - 3));
                }
            }
        }
    }

    // sollte nichts ermittelt worden sein, "- kein Eintrag gefunden -" in Liste einfügen
    if (groups.Count < 1)
        groups.Add("- kein Eintrag gefunden -");


    return groups;
}


Habt Ihr eine Idee ?