2008-10-29 4 views
22

J'écris une application Web qui utilise l'authentification Windows et je peux heureusement obtenir le nom de connexion de l'utilisateur en utilisant quelque chose comme:Comment trouver le nom d'affichage Active Directory d'un utilisateur dans une application Web C#?

string login = User.Identity.Name.ToString(); 

Mais je ne pas besoin de leur nom d'utilisateur que je veux leur DisplayName. Je me suis cogné la tête pendant quelques heures maintenant ...

Puis-je accéder à l'AD de mon organisation via une application web?

Répondre

29

Que diriez-vous ceci:

private static string GetFullName() 
    { 
     try 
     { 
      DirectoryEntry de = new DirectoryEntry("WinNT://" + Environment.UserDomainName + "/" + Environment.UserName); 
      return de.Properties["fullName"].Value.ToString(); 
     } 
     catch { return null; } 
    } 
+0

C'est la meilleure façon de le faire pour les propriétés individuelles. – thismat

+0

Ouais, j'aime la simplicité de cette ALOT, d'autant plus que ça marche. Je te dois une boisson! – inspite

+0

Cela a fonctionné, mais les propriétés WINNT: // sont beaucoup moins compréhensives que les propriétés LDAP: // (voir http://www.rlmueller.net/Name_Attributes.htm) alors que cela fonctionne, je ne peux pas obtenir les adresses e-mail de l'utilisateur dites en utilisant le WINNT: // liant – inspite

8

Voir question connexe: Active Directory: Retrieve User information

Voir aussi: Howto: (Almost) Everything In Active Directory via C# et plus spécifiquement la section "Enumerate an object's properties".

Si vous avez un chemin pour se connecter à un groupe dans un domaine, l'extrait suivant peut être utile:

GetUserProperty("<myaccount>", "DisplayName"); 

public static string GetUserProperty(string accountName, string propertyName) 
{ 
    DirectoryEntry entry = new DirectoryEntry(); 
    // "LDAP://CN=<group name>, CN =<Users>, DC=<domain component>, DC=<domain component>,..." 
    entry.Path = "LDAP://..."; 
    entry.AuthenticationType = AuthenticationTypes.Secure; 

    DirectorySearcher search = new DirectorySearcher(entry); 
    search.Filter = "(SAMAccountName=" + accountName + ")"; 
    search.PropertiesToLoad.Add(propertyName); 

    SearchResultCollection results = search.FindAll(); 
    if (results != null && results.Count > 0) 
    { 
     return results[0].Properties[propertyName][0].ToString(); 
    } 
    else 
    { 
      return "Unknown User"; 
    } 
} 
2

Il y a un projet CodePlex pour Linq to AD , si vous êtes intéressé.

Il est également couvert dans le livre LINQ Unleashed for C# par Paul Kimmel - il utilise le projet ci-dessus comme point de départ.

non affilié à deux sources - Je viens de lire le livre récemment

3

En cas où quelqu'un prend soin j'ai réussi à se fissurer celui-ci:

 /// This is some imaginary code to show you how to use it 

     Session["USER"] = User.Identity.Name.ToString(); 
     Session["LOGIN"] = RemoveDomainPrefix(User.Identity.Name.ToString()); // not a real function :D 
     string ldappath = "LDAP://your_ldap_path"; 
     // "LDAP://CN=<group name>, CN =<Users>, DC=<domain component>, DC=<domain component>,..." 


     Session["cn"] = GetAttribute(ldappath, (string)Session["LOGIN"], "cn"); 
     Session["displayName"] = GetAttribute(ldappath, (string)Session["LOGIN"], "displayName"); 
     Session["mail"] = GetAttribute(ldappath, (string)Session["LOGIN"], "mail"); 
     Session["givenName"] = GetAttribute(ldappath, (string)Session["LOGIN"], "givenName"); 
     Session["sn"] = GetAttribute(ldappath, (string)Session["LOGIN"], "sn"); 


/// working code 

public static string GetAttribute(string ldappath, string sAMAccountName, string attribute) 
    { 
     string OUT = string.Empty; 

     try 
     { 
      DirectoryEntry de = new DirectoryEntry(ldappath); 
      DirectorySearcher ds = new DirectorySearcher(de); 
      ds.Filter = "(&(objectClass=user)(objectCategory=person)(sAMAccountName=" + sAMAccountName + "))"; 

      SearchResultCollection results = ds.FindAll(); 

      foreach (SearchResult result in results) 
      { 
       OUT = GetProperty(result, attribute); 
      } 
     } 
     catch (Exception t) 
     { 
      // System.Diagnostics.Debug.WriteLine(t.Message); 
     } 

     return (OUT != null) ? OUT : string.Empty; 
    } 

public static string GetProperty(SearchResult searchResult, string PropertyName) 
    { 
     if (searchResult.Properties.Contains(PropertyName)) 
     { 
      return searchResult.Properties[PropertyName][0].ToString(); 
     } 
     else 
     { 
      return string.Empty; 
     } 
    } 
+0

ce code a sauvé ma journée. !!!! –

4

Utilisez ceci:

string displayName = UserPrincipal.Current.DisplayName;