从LDAP获取所有组和子组以及所有成员

时间:2013-01-27 17:16:34

标签: c# active-directory ldap

我正在尝试从活动目录中获取所有组及其子组和每个组的成员,然后在树结构中链接每个组的子组,然后将结果存储到数据库中,以便我可以找出父组件和每个小组的孩子。

如何使用DirectoryServices转换以下代码以测试效果?

public static List<Group>getUsers()
    {

        // create the "context" in which to operate - your domain here, 
        // as the old-style NetBIOS domain, and the container where to operate in
        PrincipalContext ctx = new PrincipalContext(ContextType.Domain, "lin.proximus.com");

        // define a "prototype" - an example of what you're searching for
        // Here: just a simple GroupPrincipal - you want all groups
        GroupPrincipal prototype = new GroupPrincipal(ctx);

        // define a PrincipalSearcher to find those principals that match your prototype
        PrincipalSearcher searcher = new PrincipalSearcher(prototype);

        // define a list of strings to hold the group names        
        List<Group> groupNames = new List<Group>();
        int counter = 0;
        // iterate over the result of the .FindAll() call
        foreach (var gp in searcher.FindAll())
        {

            // cast result to GroupPrincipal
            GroupPrincipal groupPrincipal = gp as GroupPrincipal;

            // if everything - grab the group's name and put it into the list
            if (groupPrincipal == null) continue;

            Group group = new Group();
            group.Name = groupPrincipal.Name;
            group.Description = groupPrincipal.Description;
            AddSubGroups(groupPrincipal, ref group);
            AddMemebers(groupPrincipal, ref group);
            counter++;
            groupNames.Add(group);
            Console.WriteLine(counter);
            if (counter > 10000)
                return groupNames;
        }
        return groupNames;
    }

    private static void AddSubGroups(GroupPrincipal gp,ref Group gr)
    {
        gr.SubCounts = 0;
        if (gp.GetGroups().Count() <= 0) return;

        gr.SubCounts = gp.GetGroups().Count();
        gr.SubGroups = new List<string>();
        foreach (var principal in gp.GetGroups())
        {
            gr.SubGroups.Add(principal.Name);
        }
    }

    private static void AddMemebers(GroupPrincipal gp, ref Group gr)
    {
        if (gp.GetMembers().Count() <= 0) return;

        gr.Users = new List<string>();

        foreach (Principal principal in gp.GetMembers())
        {
            gr.Users.Add(principal.Name);
        }
    }

1 个答案:

答案 0 :(得分:0)

我是Marc的第二个建议 - 使用分页和相应的pagesize属性值来提高性能。 AFAIK,如果您要获得可能具有&gt;的属性,则分页几乎是必不可少的。 999个值,例如小组成员。