1

帮助我试图从本地组中删除域用户,每次我尝试为域用户获取本地组时,集合都是空的。如何从我机器上的任何本地组中删除域用户。下面是我正在使用的代码,它适用于本地用户,但如上所述域用户它说他们没有本地组。我知道域用户位于本地计算机上的用户和 IIS_USRS 组中。

using (PrincipalContext localContext = new PrincipalContext(ContextType.Machine))
            {
                try
                {
                    foreach (GroupPrincipal principal in user.GetGroups(localContext))
                    {
                        principal.Members.Remove(user);
                        principal.Save(localContext);
                        principal.Dispose();
                    }
                }
4

1 回答 1

0

为了让它发挥作用,我最终不得不这样做。

using (PrincipalContext localContext = new PrincipalContext(ContextType.Machine))
            {
                try
                {
                    foreach (string g in groups)
                    {
                        using (GroupPrincipal localGroup = GroupPrincipal.FindByIdentity(localContext, IdentityType.Name, g))
                        {
                            foreach (Principal groupUser in localGroup.GetMembers().Where(groupUser => user.Name.Equals(groupUser.Name)))
                            {
                                localGroup.Members.Remove(groupUser);
                                localGroup.Save();
                            }
                        }
                    }
                }
于 2012-12-11T18:44:55.343 回答