Como direcionar para páginas específicas de determinado tipo de usuário no ASP.NET Identity?
11/10/2018
0
Estou usando o ASP.NET.Core.Identity (2.1.3) e gostaria que, no processo de autenticação, o usuário, caso fosse do tipo User (comum) fosse para a página HomeUser, caso fosse Admin, fosse para a página HomeAdmin. Mas como ainda conheço pouco das tecnologias, estou cheio de dúvidas:
1. Admin ou User serão Role ou Claim, no Identity?
2. Tenho as tabelas dbo.AspNetRoleClaims e dbo.AspNetRoles, dependendo da que eu escolher, o cadastro eu faço direto no banco, certo?
3. No código abaixo é que eu quero fazer o redirecionamento, como seria a verificação do claim ou role no código abaixo?
4. O código abaixo é do registro de usuário, como podem ver eu não defino o claim ou role, como insiro esse registro para o usuário?
Como podem ver eu conheço quase nada do Identity, se puderem me indicar um material mais atual e bom para eu estudar, agradeço muito!
1. Admin ou User serão Role ou Claim, no Identity?
2. Tenho as tabelas dbo.AspNetRoleClaims e dbo.AspNetRoles, dependendo da que eu escolher, o cadastro eu faço direto no banco, certo?
3. No código abaixo é que eu quero fazer o redirecionamento, como seria a verificação do claim ou role no código abaixo?
[HttpPost] [AllowAnonymous] [ValidateAntiForgeryToken] public async Task<IActionResult> Login(LoginViewModel model, string returnUrl = null) { ViewData["ReturnUrl"] = returnUrl; if (ModelState.IsValid) { // This doesn't count login failures towards account lockout // To enable password failures to trigger account lockout, set lockoutOnFailure: true var result = await _signInManager.PasswordSignInAsync(model.Email, model.Password, model.RememberMe, lockoutOnFailure: false); if (result.Succeeded) { _logger.LogInformation("Usuário logado."); //return RedirectToLocal(returnUrl); return RedirectToAction("HomeAdmin", "Account"); } if (result.IsLockedOut) { _logger.LogWarning("User account locked out."); return RedirectToAction(nameof(Lockout)); } else { ModelState.AddModelError("InvalidLogin", "O usuário ou senha incorreto."); return View(); } } // If we got this far, something failed, redisplay form return View(model); }
4. O código abaixo é do registro de usuário, como podem ver eu não defino o claim ou role, como insiro esse registro para o usuário?
[HttpPost] [AllowAnonymous] [ValidateAntiForgeryToken] public async Task<IActionResult> Register(RegisterViewModel model) { if (ModelState.IsValid) { var user = new ApplicationUser { FirstName = model.FirstName, LastName = model.LastName, UserName = model.Email, Email = model.Email, Profile = "user" }; var result = await _userManager.CreateAsync(user, model.Password); if (result.Succeeded) { _logger.LogInformation("O usuário criou uma nova conta com senha."); var code = await _userManager.GenerateEmailConfirmationTokenAsync(user); var callbackUrl = Url.Action("ConfirmEmail", "Account", new { userId = user.Id, code = code }, protocol: HttpContext.Request.Scheme); // await IEmailSender.SendEmailAsync(model.Email, "Confirm your account", $"Por favor, confirme seu email clicando neste link: <a href=''>link</a>"); await _signInManager.SignInAsync(user, isPersistent: false); _logger.LogInformation("O usuário criou uma nova conta com senha."); return RedirectToLocal("DisplayEmail"); } AddErrors(result); } // No caso de falha, reexibir a view return View(); }
Como podem ver eu conheço quase nada do Identity, se puderem me indicar um material mais atual e bom para eu estudar, agradeço muito!
Cesar Murilo
Curtir tópico
+ 0
Responder
Clique aqui para fazer login e interagir na Comunidade :)