What is the difference between System.Web.HttpContext.Current.User.Identity.Name
and System.Environment.UserName
in the context of a ASP.Net Web Application Project?
Here's the code of what I'm trying to do:
Database myDB = DatabaseFactory.CreateDatabase(); bool IsAuthUser = myDB.ExecuteScalar("procIsAuthorizedUser", System.Environment.UserName);
If they are functionally identical, which is better in terms of performance?
This is a C# 4.0/ASP.Net web application which will see moderate usage internally in the organization. Thank you for the answers.
It just holds the username of the user that is currently logged in. After login successful authentication, the username is automatically stored by login authentication system to "HttpContext.Current.User.Identity.Name" property.
It is most likely stored in Managed Passwords: Click Start > Run. Enter "control userpasswords2"
isauthenticated is False when a user is already logged in.
When an HTTP request arrives at the server, the server processes the request and builds an HttpContext object. This object represents the request which your application code can use to create the response. The HttpContext object constructed by the ASP.NET Core web server acts as a container for a single request.
System.Web.HttpContext.Current.User.Identity.Name
Gets or sets security information for the current HTTP request. (The Name of the Logged in user on your Website)
System.Environment.UserName
Gets the user name of the person who is currently logged on to the Windows operating system.
System.Environment.UserName
returns the identity under which the app pool that hosts your web app is running. If you're using Windows authentication and impersonation then it will be the actual user's name, however in all cases you're better off using the information provided by the HTTP context. There is no performance hit either way.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With