¿Cómo puedo obtener la unidad organizativa del usuario conectado en C #?

StackOverflow https://stackoverflow.com/questions/296466

  •  08-07-2019
  •  | 
  •  

Pregunta

Estoy buscando un método para obtener la ruta LDAP de Active Directory completa del usuario conectado actualmente. p.ej.

LDAP://CN=john.smith,OU=UK,OU=Sales,DC=Company,DC=local
¿Fue útil?

Solución

Consulte el directorio LDAP (por ejemplo, el AD) con este filtro:

(&(objectCategory=user)(sAMAccountName=<user-logon-name-here>))

El DN del objeto devuelto es lo que está buscando.

Algo como esto:

DirectorySearcher ds = new DirectorySearcher();
string userName = WindowsIdentity.GetCurrent().Name;
string userFilter = "(&(objectCategory=user)(sAMAccountName={0}))";

ds.SearchScope = SearchScope.Subtree;
ds.PropertiesToLoad.Add("distinguishedName");
ds.PageSize = 1;
ds.ServerPageTimeLimit = TimeSpan.FromSeconds(2);
ds.Filter = string.Format(userFilter, userName);

SearchResult sr = ds.FindOne();
// now do something with sr.Properties["distinguishedName"][0]
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top