Я розробляю веб-додаток MVC 5, використовуючи перший підхід до бази даних Entity Framework 5 . Я використовую OWIN для автентифікації користувачів. Нижче показаний метод мого входу в контролер акаунта.
public ActionResult Login(LoginViewModel model, string returnUrl)
{
if (ModelState.IsValid)
{
var user = _AccountService.VerifyPassword(model.UserName, model.Password, false);
if (user != null)
{
var identity = new ClaimsIdentity(new[] { new Claim(ClaimTypes.Name, model.UserName), }, DefaultAuthenticationTypes.ApplicationCookie, ClaimTypes.Name, ClaimTypes.Role);
identity.AddClaim(new Claim(ClaimTypes.Role, "guest"));
identity.AddClaim(new Claim(ClaimTypes.GivenName, "A Person"));
identity.AddClaim(new Claim(ClaimTypes.Sid, user.userID)); //OK to store userID here?
AuthenticationManager.SignIn(new AuthenticationProperties
{
IsPersistent = model.RememberMe
}, identity);
return RedirectToAction("Index", "MyDashboard");
}
else
{
ModelState.AddModelError("", "Invalid username or password.");
}
}
// If we got this far, something failed, redisplay form
return View(model);
}
Як ви бачите, я створюю ClaimsIdentity і додаю до нього кілька претензій, а потім передаю його OWIN, використовуючи AuthenticationManager для виконання входу.
Проблема, яка у мене виникає, полягає в тому, що я не знаю, як отримати доступ до претензій в решті моєї програми, як у контролерах, так і в представленнях Razor Views.
Я спробував підхід, перелічений у цьому підручнику
Наприклад, я спробував це у своєму коді контролера, намагаючись отримати доступ до значень, переданих у формулу заявки, однак, користувач. Претензії дорівнює нулю
var ctx = HttpContext.GetOwinContext();
ClaimsPrincipal user = ctx.Authentication.User;
IEnumerable<Claim> claims = user.Claims;
Можливо, мені щось тут не вистачає.
ОНОВЛЕННЯ
На основі відповіді Даріна я додав його код, але все ще не бачу доступу до претензій. Перегляньте знімок екрана нижче, де відображається те, що я бачу, коли наближається над особистістю.