Solved

Get UPN or email for logged in user in a .NET web application

Posted on 2009-07-08
1
920 Views
Last Modified: 2012-05-07
I have an ASP. NET web application that makes user of the user credentials of the logged in user. Currently it uses the SID which comes from

System.Security.Principal.WindowsIdentity.GetCurrent().User.Value

I need to get either the users UPN login or email address (as defined in active directory) instead of the SID. GetCurrent() returns an object of type WindowsIdentity; looking in the details for WindowsIdentity Members:

http://msdn.microsoft.com/en-us/library/system.security.principal.windowsidentity%5Fmembers.aspx

I can't see anything that looks like it would give me either the UPN or email in there. How can I pull up that information to use, either by feeding the SID into some other function or calling something different in the first place.

System.Security.Principal.WindowsIdentity.GetCurrent().Name returns "DOMAIN\user", so that is not the answer.

0
Comment
Question by:DrStalker
1 Comment
 
LVL 12

Accepted Solution

by:
Hairbrush earned 500 total points
ID: 24811676
Try this, which requires System.DirectoryServices.


   private string CurrentUserEmail()
   {
		string tempCurrentUserEmail = null;
 
		//Returns the email address of the current user from Active Directory
 
		string sCurrentUser = System.Security.Principal.WindowsIdentity.GetCurrent().Name;
 
		sCurrentUser = sCurrentUser.Substring(sCurrentUser.IndexOf("\\") + 1);
		DirectoryEntry Entry = new DirectoryEntry("LDAP://RootDSE");
		string sFQDN = System.Convert.ToString(Entry.Properties["defaultNamingContext"].Value);
		DirectoryEntry myDE = new DirectoryEntry("LDAP://" + sFQDN);
 
		DirectorySearcher mySearcher = new DirectorySearcher(myDE);
 
		mySearcher.Filter = "sAMAccountName=" + sCurrentUser;
		mySearcher.PropertiesToLoad.Add("Mail");
		try
		{
			SearchResult myresult = mySearcher.FindOne();
			tempCurrentUserEmail = System.Convert.ToString(myresult.Properties["Mail"][0]);
		}
		catch (Exception ex)
		{
			throw new ApplicationException("Could not establish an email address for user " + sCurrentUser);
		}
 
		return tempCurrentUserEmail;
	}

Open in new window

0

Featured Post

MIM Survival Guide for Service Desk Managers

Major incidents can send mastered service desk processes into disorder. Systems and tools produce the data needed to resolve these incidents, but your challenge is getting that information to the right people fast. Check out the Survival Guide and begin bringing order to chaos.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Just a quick little trick I learned recently.  Now that I'm using jQuery with abandon in my asp.net applications, I have grown tired of the following syntax:      (CODE) I suppose it just offends my sense of decency to put inline VBScript on a…
IntroductionWhile developing web applications, a single page might contain many regions and each region might contain many number of controls with the capability to perform  postback. Many times you might need to perform some action on an ASP.NET po…
Microsoft Active Directory, the widely used IT infrastructure, is known for its high risk of credential theft. The best way to test your Active Directory’s vulnerabilities to pass-the-ticket, pass-the-hash, privilege escalation, and malware attacks …
Email security requires an ever evolving service that stays up to date with counter-evolving threats. The Email Laundry perform Research and Development to ensure their email security service evolves faster than cyber criminals. We apply our Threat…

825 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question