В модели форм я использовал для получения текущего зарегистрированного пользователя:
Page.CurrentUser
Как получить текущего пользователя внутри класса контроллера в ASP.NET MVC?
В модели форм я использовал для получения текущего зарегистрированного пользователя:
Page.CurrentUser
Как получить текущего пользователя внутри класса контроллера в ASP.NET MVC?
Если вам нужно получить пользователя из контроллера, используйте свойство User
контроллера. Если вам нужно это из представления, я бы заполнил то, что вам особенно нужно в ViewData
, или вы можете просто позвонить пользователю, поскольку я считаю это свойством ViewPage
.
Я обнаружил, что User
работает, то есть User.Identity.Name
или User.IsInRole("Administrator")
.
Попробуйте HttpContext.Current.User
.
Общий общий ресурс недвижимости() As System.Web.HttpContext
Член System.Web.HttpContextРезюме:
Получает или задает объект System.Web.HttpContext для текущего HTTP-запроса.Возвращаемые значения:
System.Web.HttpContext для текущего HTTP-запрос
Вы можете получить имя пользователя в ASP.NET MVC4 следующим образом:
System.Web.HttpContext.Current.User.Identity.Name
Я понимаю, что это действительно старо, но я только начинаю работу с ASP.NET MVC, поэтому я думал, что буду придерживаться двух центов:
Request.IsAuthenticated
указывает, аутентифицирован ли пользователь.Page.User.Identity
предоставляет идентификатор зарегистрированного пользователя.Я использую:
Membership.GetUser().UserName
Я не уверен, что это сработает в ASP.NET MVC, но это стоит сделать:)
войти во имя пользователя: System.Web.HttpContext.Current.User.Identity.Name
Чтобы ссылаться на идентификатор пользователя, созданный с использованием простой аутентификации, встроенной в ASP.NET MVC 4, в контроллер для целей фильтрации (что полезно, если вы сначала используете базу данных и Entity Framework 5 для генерации первых кодов привязки и ваших таблиц структурированы так, что используется внешний ключ для идентификатора пользователя), вы можете использовать
WebSecurity.CurrentUserId
после добавления оператора using
using System.Web.Security;
Имя_пользователя:
User.Identity.Name
Но если вам нужно получить только идентификатор, вы можете использовать:
using Microsoft.AspNet.Identity;
Итак, вы можете получить прямой идентификатор пользователя:
User.Identity.GetUserId();
Эта страница может быть тем, что вы ищете:
Использование параметра Page.User.Identity.Name в MVC3
Вам просто нужно User.Identity.Name
.
Используйте System.Security.Principal.WindowsIdentity.GetCurrent().Name
.
Это приведет к загрузке текущего пользователя Windows.
Для чего стоит, в ASP.NET MVC 3 вы можете просто использовать User, который возвращает пользователя для текущего запроса.
Если вы находитесь на своей странице входа в систему, например, в LoginUser_LoggedIn, Current.User.Identity.Name вернет пустое значение, поэтому вам нужно использовать свойство yourLoginControlName.UserName.
MembershipUser u = Membership.GetUser(LoginUser.UserName);
Мы можем использовать следующий код, чтобы получить текущий зарегистрированный пользователь в ASP.Net MVC:
var user= System.Web.HttpContext.Current.User.Identity.GetUserName();
Также
var userName = System.Security.Principal.WindowsIdentity.GetCurrent().Name; //will give 'Domain//UserName'
Environment.UserName - Will Display format : 'Username'
IPrincipal currentUser = HttpContext.Current.User;
bool writeEnable = currentUser.IsInRole("Administrator") ||
...
currentUser.IsInRole("Operator");
var ticket = FormsAuthentication.Decrypt(
HttpContext.Current.Request.Cookies[FormsAuthentication.FormsCookieName].Value);
if (ticket.Expired)
{
throw new InvalidOperationException("Ticket expired.");
}
IPrincipal user = (System.Security.Principal.IPrincipal) new RolePrincipal(new FormsIdentity(ticket));
Если вы работаете в Active Directory в интрасети, вот несколько советов:
(Windows Server 2012)
Запуск чего-либо, связанного с AD на веб-сервере, требует кучи изменений и терпения. Поскольку при работе на веб-сервере и локальном IIS/IIS Express он запускается в идентификаторе AppPool, поэтому вы должны настроить его для олицетворения тех, кто попадает на сайт.
Как получить текущего зарегистрированного пользователя в активном каталоге, когда приложение ASP.NET MVC запущено на веб-сервере внутри сети:
// Find currently logged in user
UserPrincipal adUser = null;
using (HostingEnvironment.Impersonate())
{
var userContext = System.Web.HttpContext.Current.User.Identity;
PrincipalContext ctx = new PrincipalContext(ContextType.Domain, ConfigurationManager.AppSettings["AllowedDomain"], null,
ContextOptions.Negotiate | ContextOptions.SecureSocketLayer);
adUser = UserPrincipal.FindByIdentity(ctx, userContext.Name);
}
//Then work with 'adUser' from here...
Вы должны обернуть любые вызовы, связанные с "контекстом активной директории", следующим образом, чтобы он работал в качестве среды размещения для получения информации AD:
using (HostingEnvironment.Impersonate()){ ... }
У вас также должно быть impersonate
установлено значение true в вашем web.config:
<system.web>
<identity impersonate="true" />
У вас должна быть аутентификация Windows в web.config:
<authentication mode="Windows" />
Вы можете использовать следующий код:
Request.LogonUserIdentity.Name;
В Asp.net Mvc Identity 2 вы можете получить текущее имя пользователя:
var username = System.Web.HttpContext.Current.User.Identity.Name;
В диспетчере IIS в разделе "Аутентификация" отключите: 1) анонимную аутентификацию 2) аутентификацию с помощью форм
Затем добавьте следующее к своему контроллеру для обработки тестирования по сравнению с развертыванием сервера:
string sUserName = null;
string url = Request.Url.ToString();
if (url.Contains("localhost"))
sUserName = System.Security.Principal.WindowsIdentity.GetCurrent().Name;
else
sUserName = User.Identity.Name;