Solved

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

Posted on 2009-07-08
1
945 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
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
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

Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

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

In my previous two articles we discussed Binary Serialization (http://www.experts-exchange.com/A_4362.html) and XML Serialization (http://www.experts-exchange.com/A_4425.html). In this article we will try to know more about SOAP (Simple Object Acces…
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.
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…

740 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