Поиск пользователя через GroupPrincipal - PullRequest
1 голос
/ 17 ноября 2010

В моем Active Directory (my.domain) у меня много групп (UserGrp1, UserGrp2 и т. Д.), В которых много пользователей. Пользователь может существовать в нескольких группах. В настоящее время у меня есть код, который позволяет мне использовать класс GroupPrincipal для поиска группы, а затем оттуда получить всех членов этой группы (см. Код ниже). Однако мне действительно нужно найти все группы, к которым принадлежит пользователь. Например, у меня есть пользователь домена с именем Joe Test (sAMAccountName = JOETEST), и мне нужно найти все группы, к которым он принадлежит , Каков наилучший способ сделать это?

Я могу определить, принадлежит ли пользователь группе (как показано ниже), прокручиваю ли я все члены, возвращенные методом GetMembers (), но это кажется мне неэффективным, и я был бы удивлен, если бы не было более эффективного способа .

using (PrincipalContext ctx = new PrincipalContext(
  ContextType.Domain, "my.domain", "DC=my,DC=domain")) {

  if (ctx != null) {
    using (GroupPrincipal gp = GroupPrincipal.FindByIdentity(ctx, "UserGrp1")) {
      // Get all group members
      PrincipalSearchResult<Principal> psr = gp.GetMembers();
      foreach (Principal p in psr) {
         // other logic 
      }
    }
  }
}

Заранее спасибо за любую помощь, которую я получаю по этому вопросу.

1 Ответ

3 голосов
/ 18 ноября 2010

Сделайте это, используя UserPrincipal.GetGroups();

Для полного кода здесь это

/// <summary>
/// Gets a list of the users group memberships
/// </summary>
/// <param name="sUserName">The user you want to get the group memberships</param>
/// <returns>Returns an arraylist of group memberships</returns>
public ArrayList GetUserGroups(string sUserName)
{
    ArrayList myItems = new ArrayList();
    UserPrincipal oUserPrincipal = GetUser(sUserName);

    PrincipalSearchResult<Principal> oPrincipalSearchResult = oUserPrincipal.GetGroups();

    foreach (Principal oResult in oPrincipalSearchResult)
    {
        myItems.Add(oResult.Name);
    }
    return myItems;
}



/// <summary>
/// Gets a certain user on Active Directory
/// </summary>
/// <param name="sUserName">The username to get</param>
/// <returns>Returns the UserPrincipal Object</returns>
public UserPrincipal GetUser(string sUserName)
{
    PrincipalContext oPrincipalContext = GetPrincipalContext();

    UserPrincipal oUserPrincipal = UserPrincipal.FindByIdentity(oPrincipalContext, sUserName);
    return oUserPrincipal;
}


/// <summary>
/// Gets the base principal context
/// </summary>
/// <returns>Retruns the PrincipalContext object</returns>
public PrincipalContext GetPrincipalContext()
{
    PrincipalContext oPrincipalContext = new PrincipalContext(ContextType.Domain, sDomain, sDefaultOU, ContextOptions.SimpleBind, sServiceUser, sServicePassword);
    return oPrincipalContext;
}

или для полной ссылки AD перейдите здесь .

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...