通过 .net 获取 Active Directory 组中的用户名

时间:2022-11-20
本文介绍了通过 .net 获取 Active Directory 组中的用户名的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

下面的代码让我得到组中的用户,但它被返回"CN=johnson,Tom,OU=Users,OU=Main,DC=company,DC=com"

The below code gets me the users in the group but it is returned "CN=johnson,Tom,OU=Users,OU=Main,DC=company,DC=com"

我只想返回名字和姓氏.我怎样才能做到这一点?

I want to just return the First and Last name. How can I accomplish this?

DirectoryEntry ou = new DirectoryEntry();
DirectorySearcher src = new DirectorySearcher();

src.Filter = ("(&(objectClass=group)(CN=Gname))");
SearchResult res = src.FindOne();
if (res != null)
{
    DirectoryEntry deGroup = new DirectoryEntry(res.Path);
    PropertyCollection pcoll = deGroup.Properties;

    foreach (object obj in deGroup.Properties["member"])
    {
            ListBox1.Items.Add(obj.ToString());
    }
}

推荐答案

我更喜欢使用 System.DirectoryServices.AccountManagement 中的类:

I prefer using the classes in System.DirectoryServices.AccountManagement:

PrincipalContext principalContext = new PrincipalContext(ContextType.Domain);
GroupPrincipal group = GroupPrincipal.FindByIdentity(principalContext, "GName");

搜索 group.Members 属性,直到您拥有所需的 Principal.然后像这样提取名称:

Search through the group.Members property until you have a Principal that you want. Then extract the name like this:

foreach (Principal principal in group.Members)
{
   string name = principal.Name;
}

这篇关于通过 .net 获取 Active Directory 组中的用户名的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

上一篇:以编程方式确定 AD 密码策略 下一篇:是否有一个 .NET 类可以解析 LDAP 中的 CN= 字符串?

相关文章

最新文章