检查嵌套AD组中的用户成员身份

时间:2014-03-07 21:06:09

标签: c# asp.net-mvc active-directory directoryservices

我有一个带有以下函数的ASP.NET Framework 4.5应用程序,用于检查用户是否是AD组的成员:

public static bool IsUserGroupMember(string userName, string groupName)
{
    string domain = "ad.our.org";
    string defaultOU = "OU=Our_Department,DC=ad,DC=our,DC=org";
    PrincipalContext principalContext = new PrincipalContext(ContextType.Domain, domain, defaultOU, ContextOptions.SimpleBind);
    UserPrincipal userPrincipal = UserPrincipal.FindByIdentity(principalContext, userName);
    GroupPrincipal groupPrincipal = GroupPrincipal.FindByIdentity(principalContext, groupName);

    return oGroupPrincipal.Members.Contains(oUserPrincipal);
}

但是,这仅在用户直接是该组的成员而不是嵌套在该组中的其他组的成员时才有效。

希望获得帮助修复此代码,以便通过组内的每个嵌套组递归检查成员资格。我查看了StackOverflow中类似问题的答案,但无法弄清楚如何最好地修改我的函数以使其工作。

感谢。

1 个答案:

答案 0 :(得分:9)

这就是你想要的:

public static bool IsUserGroupMember(string userName, string groupName)
{
    using (PrincipalContext context = new PrincipalContext(ContextType.Domain))
    using (UserPrincipal user = UserPrincipal.FindByIdentity(context, userName))
    using (PrincipalSearchResult<Principal> groups = user.GetAuthorizationGroups())
    {
        return groups.OfType<GroupPrincipal>().Any(g => g.Name.Equals(groupName, StringComparison.OrdinalIgnoreCase));
    }
}