我正在为我的应用程序使用 ASP.Net identity 2.0 包。用户成功登录后,我想将他们重定向到站点上的特定 URL。目前,授权成功后,将它们发送回默认索引页面。
我认为它在 AccountController.cs 的这一部分中的某处:
//
// POST: /Account/Login
[HttpPost]
[AllowAnonymous]
[ValidateAntiForgeryToken]
public async Task<ActionResult> Login(LoginViewModel model, string returnUrl)
{
if (!ModelState.IsValid)
{
return View(model);
}
// This doen't count login failures towards lockout only two factor authentication
// To enable password failures to trigger lockout, change to shouldLockout: true
var result = await SignInManager.PasswordSignInAsync(model.UserName, model.Password, model.RememberMe, shouldLockout: false);
var user = await UserManager.FindByNameAsync(model.UserName);
switch (result)
{
case SignInStatus.Success:
if (user.LoginStage <= 0)
{
return RedirectToAction("EnableGoogleAuthenticator", "Manage");
}
else
{
return RedirectToLocal(returnUrl);
}
case SignInStatus.LockedOut:
return View("Lockout");
case SignInStatus.RequiresVerification:
return RedirectToAction("SendCode", new { ReturnUrl = returnUrl });
case SignInStatus.Failure:
default:
ModelState.AddModelError("", "Invalid login attempt.");
await SignInManager.PasswordSignInAsync(model.UserName, model.Password, model.RememberMe, shouldLockout: true);
return View(model);
}
}
最佳答案
将 RedirectToLocal(returnUrl);
更改为 return RedirectToAction("Action", "Controller");
但这意味着您忽略了 returnUrl
。
关于c# - 在 ASP.net Identity 中,如何在登录后将用户重定向到特定的 url?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33589191/