随笔 - 15  文章 - 4  评论 - 4  阅读 - 6737

对域中OU的遍历

protected void Page_Load(object sender, EventArgs e)
    {
        DirectoryEntry de = new DirectoryEntry(ldap, admin, pwd);
        TreeNode root = new TreeNode("root", "root");
        TreeNode tn;
        foreach (DirectoryEntry child in de.Children)  //循环遍历根目录下的OU
        {
            if (child.Name.Contains("OU"))
            {
                string ou = child.Name.Split(new char[] { '=' })[1].ToString();
                string url = child.Properties["distinguishedName"].Value.ToString();
               
                DirectoryEntry dir = new DirectoryEntry(ldapIP+url,admin, pwd);
                tn = new TreeNode();
                tn.Text = ou;

               
                this.treeView(dir, tn);
                root.ChildNodes.Add(tn);

            }
        }
        this.TreeView1.Nodes.Add(root);

    }

public void treeView(DirectoryEntry de,TreeNode root) //遍历每个根目录OU中的OU
    {
        foreach (DirectoryEntry child in de.Children)
        {
            if (child.Name.Contains("OU"))
            {
                string ou = child.Name.Split(new char[] { '=' })[1].ToString();
              
                string url = child.Properties["distinguishedName"].Value.ToString();
                DirectoryEntry dir = new DirectoryEntry(ldapIP+url, admin, pwd);
                TreeNode tree = new TreeNode();
                tree.Text = ou;
               
                this.treeView(dir, tree);
                root.ChildNodes.Add(tree);

     
            }
            else
            {
                TreeNode leaf = new TreeNode();
                if (child.Properties["displayName"].Value != null)
                {
                    leaf.Text = child.Properties["displayName"].Value.ToString();
                    if (child.Properties["mobile"].Value != null)
                    {
                        leaf.Value = child.Properties["mobile"].Value.ToString();
                    }
                    else
                    {
                        leaf.Value = "0";
                    }
                    root.ChildNodes.Add(leaf);
                }
            }
          
           
        }
    }

posted on   大胖头  阅读(623)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
< 2007年4月 >
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 1 2 3 4 5
6 7 8 9 10 11 12

点击右上角即可分享
微信分享提示