主体已经存在LDAP C#

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了主体已经存在LDAP C#相关的知识,希望对你有一定的参考价值。

我正在尝试使用MVC C#LDAP更新Active Directory上的用户,如果用户已经在组中,我首先将其从组中删除,然后使用Principal上下文再次添加该用户。我试图在我的删除循环结束时提交更改,但这无济于事

这是我的代码删除代码:

PropertyValueCollection groups = result.GetDirectoryEntry().Properties["memberOf"];
                if (groups != null)
                
                    for (int i = 0; i < groups.Count; i++)
                    
                        string groupDn = (string)groups[i];

                        DirectoryEntry group = new DirectoryEntry("LDAP://" + groupDn, null, null);
                        if (group != null)
                        
                            group.Invoke("Remove", new object[]  result.Path );
                        
                        group.CommitChanges();
                    
                

将用户添加到组的代码

    //DirectoryEntry dirEntry = new DirectoryEntry(groupDirectoryEntry);
                using (PrincipalContext pc = new PrincipalContext(ContextType.Domain, AD_Address))// "10.125.153.30"))
                
                    foreach (var rights in accessGroupList)
                    
                        GroupPrincipal group = GroupPrincipal.FindByIdentity(pc, rights);
                        group.Members.Add(pc, IdentityType.UserPrincipalName, model.validPersalNumber); //this is where is failes
                        group.Save();
                    
                
答案

提交更改后删除组代码,我必须关闭组

 PropertyValueCollection groups = result.GetDirectoryEntry().Properties["memberOf"];
                if (groups != null)
                
                    for (int i = 0; i < groups.Count; i++)
                    
                        string groupDn = (string)groups[i];

                        DirectoryEntry group = new DirectoryEntry("LDAP://" + groupDn, null, null);
                        if (group != null)
                        
                            group.Invoke("Remove", new object[]  result.Path );
                        
                        group.CommitChanges();
                        group.Close();
                    

以上是关于主体已经存在LDAP C#的主要内容,如果未能解决你的问题,请参考以下文章

如何检查用户是不是存在于 LDAP 上

SQL Server 服务器主体拥有一个或多个端点无法删除;错误15141

Django项目使用LDAP的配置问题

从C#中的托管对象属性获取值的最佳方法

java ldap根据用户名查询

js之观察者模式