Solved

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

Posted on 2009-07-08
1
897 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

DevOps Toolchain Recommendations

Read this Gartner Research Note and discover how your IT organization can automate and optimize DevOps processes using a toolchain architecture.

Question has a verified solution.

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

A quick way to get a menu to work on our website, is using the Menu control and assign it to a web.sitemap using SiteMapDataSource. Example of web.sitemap file: (CODE) Sample code to add to the page menu: (CODE) Running the application, we wi…
International Data Corporation (IDC) prognosticates that before the current the year gets over disbursing on IT framework products to be sent in cloud environs will be $37.1B.
With the power of JIRA, there's an unlimited number of ways you can customize it, use it and benefit from it. With that in mind, there's bound to be things that I wasn't able to cover in this course. With this summary we'll look at some places to go…
Video by: Mark
This lesson goes over how to construct ordered and unordered lists and how to create hyperlinks.

920 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

Need Help in Real-Time?

Connect with top rated Experts

15 Experts available now in Live!

Get 1:1 Help Now