通常,由于以下原因导致用户在 Active Directory 中的更新失败:
1.用户不存在或已被删除。 2.缺少所需的权限。 3.域控制器不可用或未连接。 4.用户属性不正确或无效。
为了解决这个问题,可以使用以下代码:
1.确保用户存在于 Active Directory 中:
String userName = "myUserName";
DirectoryEntry entry = new DirectoryEntry("LDAP://domainName");
DirectorySearcher search = new DirectorySearcher(entry);
search.Filter = "(&(objectClass=user)(sAMAccountName=" + userName + "))";
SearchResult result = search.FindOne();
if(result == null)
{
//用户不存在
}
2.检查所需权限,例如修改用户属性的权限:
DirectoryEntry entry = new DirectoryEntry("LDAP://CN=myUserName,DC=domainName,DC=com");
DirectoryEntry parent = entry.Parent;
string username = "myUsername";
string password = "myPassword";
bool isAuth = false;
string domain = "domainName.com";
try
{
//使用用户凭据认证
parent.Username = domain + "\\" + username;
parent.Password = password;
parent.AuthenticationType = AuthenticationTypes.Secure;
isAuth = true;
}
catch (Exception ex)
{
isAuth = false;
}
//检查用户权限
if (isAuth)
{
if (!entry.Properties.Contains("ms-DS-AllowedToDelegateTo"))
return "用户没有权利修改属性!";
}
else
return "用户验证失败!";
3.检查域控制器的可用性和连接状态:
DirectoryContext context = new DirectoryContext(DirectoryContextType.Domain, "domainName");
Domain domain = Domain.GetDomain(context);
DomainController dc = domain.FindDomainController();
DirectoryEntry entry = dc.GetDirectoryEntry();
if (entry == null)
{
//连接失败
}
4.验证用户属性的正确性和有效性,例如姓名、电子邮件等:
DirectoryEntry entry = new DirectoryEntry