Я делал это раньше с использованием MVC5, User.Identity.GetUserId()
но здесь это не работает. User.Identity
Оленья кожа имеет GetUserId()
метод
Я использую Microsoft.AspNet.Identity
Я делал это раньше с использованием MVC5, User.Identity.GetUserId()
но здесь это не работает. User.Identity
Оленья кожа имеет GetUserId()
метод
Я использую Microsoft.AspNet.Identity
Ответы:
В контроллере:
public class YourControllerNameController : Controller
{
private readonly UserManager<ApplicationUser> _userManager;
public YourControllerNameController(UserManager<ApplicationUser> userManager)
{
_userManager = userManager;
}
public async Task<IActionResult> YourMethodName()
{
var userId = User.FindFirstValue(ClaimTypes.NameIdentifier) // will give the user's userId
var userName = User.FindFirstValue(ClaimTypes.Name) // will give the user's userName
ApplicationUser applicationUser = await _userManager.GetUserAsync(User);
string userEmail = applicationUser?.Email; // will give the user's Email
}
}
В каком-то другом классе:
public class OtherClass
{
private readonly IHttpContextAccessor _httpContextAccessor;
public OtherClass(IHttpContextAccessor httpContextAccessor)
{
_httpContextAccessor = httpContextAccessor;
}
public void YourMethodName()
{
var userId = _httpContextAccessor.HttpContext.User.FindFirstValue(ClaimTypes.NameIdentifier);
}
}
Тогда вы должны зарегистрироваться IHttpContextAccessor
в Startup
классе следующим образом:
public void ConfigureServices(IServiceCollection services)
{
services.TryAddSingleton<IHttpContextAccessor, HttpContextAccessor>();
// Or you can also register as follows
services.AddHttpContextAccessor();
}
Для большей читабельности напишите методы расширения следующим образом:
public static class ClaimsPrincipalExtensions
{
public static T GetLoggedInUserId<T>(this ClaimsPrincipal principal)
{
if (principal == null)
throw new ArgumentNullException(nameof(principal));
var loggedInUserId = principal.FindFirstValue(ClaimTypes.NameIdentifier);
if (typeof(T) == typeof(string))
{
return (T)Convert.ChangeType(loggedInUserId, typeof(T));
}
else if (typeof(T) == typeof(int) || typeof(T) == typeof(long))
{
return loggedInUserId != null ? (T)Convert.ChangeType(loggedInUserId, typeof(T)) : (T)Convert.ChangeType(0, typeof(T));
}
else
{
throw new Exception("Invalid type provided");
}
}
public static string GetLoggedInUserName(this ClaimsPrincipal principal)
{
if (principal == null)
throw new ArgumentNullException(nameof(principal));
return principal.FindFirstValue(ClaimTypes.Name);
}
public static string GetLoggedInUserEmail(this ClaimsPrincipal principal)
{
if (principal == null)
throw new ArgumentNullException(nameof(principal));
return principal.FindFirstValue(ClaimTypes.Email);
}
}
Затем используйте следующее:
public class YourControllerNameController : Controller
{
public IActionResult YourMethodName()
{
var userId = User.GetLoggedInUserId<string>(); // Specify the type of your UserId;
var userName = User.GetLoggedInUserName();
var userEmail = User.GetLoggedInUserEmail();
}
}
public class OtherClass
{
private readonly IHttpContextAccessor _httpContextAccessor;
public OtherClass(IHttpContextAccessor httpContextAccessor)
{
_httpContextAccessor = httpContextAccessor;
}
public void YourMethodName()
{
var userId = _httpContextAccessor.HttpContext.User.GetLoggedInUserId<string>(); // Specify the type of your UserId;
}
}
null
.
User.Identity.Name
, это может быть потому, что включена анонимная аутентификация. Я смог User.Identity.Name
вернуть свой домен и имя пользователя, расширив Properties > launchSettings.json
и настроив anonymousAuthentication
до false
и windowsAuthentication
до true
.
До ASP.NET Core 1.0 RC1 :
Это User.GetUserId () из пространства имен System.Security.Claims .
Начиная с ASP.NET Core 1.0 RC2 :
Теперь вы должны использовать UserManager . Вы можете создать метод для получения текущего пользователя:
private Task<ApplicationUser> GetCurrentUserAsync() => _userManager.GetUserAsync(HttpContext.User);
И получить информацию о пользователе с объектом:
var user = await GetCurrentUserAsync();
var userId = user?.Id;
string mail = user?.Email;
Примечание.
Вы можете сделать это без использования метода, пишущего одинарными строками string mail = (await _userManager.GetUserAsync(HttpContext.User))?.Email
, но это не соответствует принципу единой ответственности. Лучше изолировать способ, которым вы получаете пользователя, потому что, если когда-нибудь вы решите изменить свою систему управления пользователями, например, использовать другое решение, чем Identity, это станет болезненным, поскольку вам придется просматривать весь код.
вы можете получить его в своем контроллере:
using System.Security.Claims;
var userId = this.User.FindFirstValue(ClaimTypes.NameIdentifier);
или напишите метод расширения, как раньше .Core v1.0
using System;
using System.Security.Claims;
namespace Shared.Web.MvcExtensions
{
public static class ClaimsPrincipalExtensions
{
public static string GetUserId(this ClaimsPrincipal principal)
{
if (principal == null)
throw new ArgumentNullException(nameof(principal));
return principal.FindFirst(ClaimTypes.NameIdentifier)?.Value;
}
}
}
и получить везде, где доступен пользователь ClaimsPrincipal :
using Microsoft.AspNetCore.Mvc;
using Shared.Web.MvcExtensions;
namespace Web.Site.Controllers
{
public class HomeController : Controller
{
public IActionResult Index()
{
return Content(this.User.GetUserId());
}
}
}
var userId = User.FindFirstValue(ClaimTypes.NameIdentifier);
Convert.ToInt32(User.FindFirstValue(ClaimTypes.NameIdentifier))
чтобы получить целочисленный UserId
Я включил использование System.Security.Claims, и я мог получить доступ к методу расширения GetUserId ()
NB. Я уже использовал Microsoft.AspNet.Identity, но не смог получить метод расширения. Так что я думаю, что оба они должны использоваться в сочетании друг с другом
using Microsoft.AspNet.Identity;
using System.Security.Claims;
РЕДАКТИРОВАТЬ : Этот ответ сейчас устарел. Посмотрите на ответ Сорена или Адриена, чтобы узнать, как это сделать в CORE 1.0.
var userId = User.GetUserId();
Только для .NET Core 2.0 Для получения идентификатора пользователя вошедшего в систему пользователя в Controller
классе требуется следующее :
var userId = this.User.FindFirstValue(ClaimTypes.NameIdentifier);
или
var userId = HttpContext.User.FindFirstValue(ClaimTypes.NameIdentifier);
например
contact.OwnerID = this.User.FindFirstValue(ClaimTypes.NameIdentifier);
Как указано где-то в этом посте, метод GetUserId () был перемещен в UserManager.
private readonly UserManager<ApplicationUser> _userManager;
public YourController(UserManager<ApplicationUser> userManager)
{
_userManager = userManager;
}
public IActionResult MyAction()
{
var userId = _userManager.GetUserId(HttpContext.User);
var model = GetSomeModelByUserId(userId);
return View(model);
}
Если вы запустили пустой проект, вам может понадобиться добавить UserManger к вашим сервисам в startup.cs. В противном случае это уже должно быть.
Вы должны импортировать Microsoft.AspNetCore.Identity & System.Security.Claims
// to get current user ID
var userId = User.FindFirstValue(ClaimTypes.NameIdentifier);
// to get current user info
var user = await _userManager.FindByIdAsync(userId);
"http://schemas.xmlsoap.org/ws/2005/05/identity/claims/nameidentifier"
к User.FindFirstValue(ClaimTypes.NameIdentifier);
?
Хотя ответ Адриен верен, вы можете сделать все это в одной строке. Нет необходимости в дополнительных функциях или беспорядке.
Это работает, я проверил это в ASP.NET Core 1.0
var user = await _userManager.GetUserAsync(HttpContext.User);
тогда вы можете получить другие свойства переменной, как user.Email
. Я надеюсь, что это поможет кому-то.
Для ASP.NET Core 2.0, Entity Framework Core 2.0, API-интерфейс AspNetCore.Identity 2.0 ( https://github.com/kkagill/ContosoUniversity-Backend ):
Id
Было измененоUser.Identity.Name
[Authorize, HttpGet("Profile")]
public async Task<IActionResult> GetProfile()
{
var user = await _userManager.FindByIdAsync(User.Identity.Name);
return Json(new
{
IsAuthenticated = User.Identity.IsAuthenticated,
Id = User.Identity.Name,
Name = $"{user.FirstName} {user.LastName}",
Type = User.Identity.AuthenticationType,
});
}
Отклик:
this.User.Identity.Name
как правило, имя пользователя. В моем тесте имя пользователя - это электронное письмо, будь то пользователь, который вошел в систему после регистрации или вошел в систему с внешнего входа (например, Facebook, Google). Следующий код возвращает идентификатор пользователя. Я использую автоинкрементный первичный ключ для моей идентификационной пользовательской таблицы, следовательно, int.Parse. int userId = int.Parse(this.User.FindFirstValue(ClaimTypes.NameIdentifier));
FindByIdAsync
не работает, поскольку вы предоставляете имя пользователя. Это работает, когда вы замените его FindByNameAsync
.
User.Identity.GetUserId ();
не существует в ядре идентичности asp.net 2.0. В связи с этим мне удалось по-другому. я создал общий класс для использования всего приложения, потому что получаю информацию о пользователе.
создать общий класс PCommon и интерфейс IPCommon,
добавив ссылкуusing System.Security.Claims
using Microsoft.AspNetCore.Http;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Security.Claims;
using System.Threading.Tasks;
namespace Common.Web.Helper
{
public class PCommon: IPCommon
{
private readonly IHttpContextAccessor _context;
public PayraCommon(IHttpContextAccessor context)
{
_context = context;
}
public int GetUserId()
{
return Convert.ToInt16(_context.HttpContext.User.FindFirstValue(ClaimTypes.NameIdentifier));
}
public string GetUserName()
{
return _context.HttpContext.User.Identity.Name;
}
}
public interface IPCommon
{
int GetUserId();
string GetUserName();
}
}
Здесь реализация общего класса
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Mvc.Rendering;
using Microsoft.Extensions.Logging;
using Pay.DataManager.Concreate;
using Pay.DataManager.Helper;
using Pay.DataManager.Models;
using Pay.Web.Helper;
using Pay.Web.Models.GeneralViewModels;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
namespace Pay.Controllers
{
[Authorize]
public class BankController : Controller
{
private readonly IUnitOfWork _unitOfWork;
private readonly ILogger _logger;
private readonly IPCommon _iPCommon;
public BankController(IUnitOfWork unitOfWork, IPCommon IPCommon, ILogger logger = null)
{
_unitOfWork = unitOfWork;
_iPCommon = IPCommon;
if (logger != null) { _logger = logger; }
}
public ActionResult Create()
{
BankViewModel _bank = new BankViewModel();
CountryLoad(_bank);
return View();
}
[HttpPost, ActionName("Create")]
[ValidateAntiForgeryToken]
public async Task<IActionResult> Insert(BankViewModel bankVM)
{
if (!ModelState.IsValid)
{
CountryLoad(bankVM);
//TempData["show-message"] = Notification.Show(CommonMessage.RequiredFieldError("bank"), "Warning", type: ToastType.Warning);
return View(bankVM);
}
try
{
bankVM.EntryBy = _iPCommon.GetUserId();
var userName = _iPCommon.GetUserName()();
//_unitOfWork.BankRepo.Add(ModelAdapter.ModelMap(new Bank(), bankVM));
//_unitOfWork.Save();
// TempData["show-message"] = Notification.Show(CommonMessage.SaveMessage(), "Success", type: ToastType.Success);
}
catch (Exception ex)
{
// TempData["show-message"] = Notification.Show(CommonMessage.SaveErrorMessage("bank"), "Error", type: ToastType.Error);
}
return RedirectToAction(nameof(Index));
}
}
}
получить идентификатор пользователя и имя в действии вставки
_iPCommon.GetUserId();
Спасибо Максуд
Для получения текущего идентификатора пользователя в бритвенных представлениях мы можем внедрить UserManager в представление следующим образом:
@inject Microsoft.AspNetCore.Identity.UserManager<ApplicationUser> _userManager
@{ string userId = _userManager.GetUserId(User); }
Я надеюсь, что вы найдете это полезным.
Как администратор, работающий над профилем других людей, и вам необходимо получить идентификатор профиля, над которым вы работаете, вы можете использовать ViewBag для захвата идентификатора, например ViewBag.UserId = userId; userId - это строковый параметр метода, с которым вы работаете.
[HttpGet]
public async Task<IActionResult> ManageUserRoles(string userId)
{
ViewBag.UserId = userId;
var user = await userManager.FindByIdAsync(userId);
if (user == null)
{
ViewBag.ErrorMessage = $"User with Id = {userId} cannot be found";
return View("NotFound");
}
var model = new List<UserRolesViewModel>();
foreach (var role in roleManager.Roles)
{
var userRolesViewModel = new UserRolesViewModel
{
RoleId = role.Id,
RoleName = role.Name
};
if (await userManager.IsInRoleAsync(user, role.Name))
{
userRolesViewModel.IsSelected = true;
}
else
{
userRolesViewModel.IsSelected = false;
}
model.Add(userRolesViewModel);
}
return View(model);
}
Если вы хотите это в ASP.NET MVC Controller, используйте
using Microsoft.AspNet.Identity;
User.Identity.GetUserId();
Вам нужно добавить using
заявление, потому GetUserId()
что без него не будет.
User.GetUserId()
а неUser.Identity.GetUserId()
System.Web.HttpContext.Current.User.Identity.Name
?