在 ASP.NET Core Identity 中,使用身份验证后,要想将用户重定向到受限制的页面,我们可以使用ReturnUrl参数。但是,在某些情况下,即使使用了 ReturnUrl,重定向也可能无法起作用。这可能是由于 ASP.NET Core Identity 框架的某些问题引起的。
一个解决方法是在登录方法中手动重定向用户并设置 ReturnUrl 参数。以下是一个简单的代码示例:
[HttpPost]
[AllowAnonymous]
[ValidateAntiForgeryToken]
public async Task Login(LoginViewModel model, string returnUrl = null)
{
returnUrl = returnUrl ?? Url.Content("~/");
if (ModelState.IsValid)
{
var result = await _signInManager.PasswordSignInAsync(model.Email, model.Password, model.RememberMe, lockoutOnFailure: false);
if (result.Succeeded)
{
return LocalRedirect(returnUrl);
}
ModelState.AddModelError(string.Empty, "Invalid login attempt.");
return View(model);
}
return View(model);
}
在该示例中,我们在登录方法中手动设置 ReturnUrl,并将其传递给LocalRedirect方法,以便在成功登录时重定向用户。
另一个解决方法是通过添加以下中间件来解决 ASP.NET Core Identity 的问题:
app.Use(async (context, next) => {
await next();
if (context.Response.StatusCode == 401 && !context.Request.Path.Value.StartsWith("/api"))
{
context.Response.Redirect("/Account/Login?returnUrl=" + context.Request.Path);
}
});
此中间件将检测 HTTP 状态码是否为 401(用户未经身份验证)并将其重定向到登录页面。
总之,以上是两个在 ASP.NET Core Identity (.Net 5) 中修复登录后重定向不起作用的解决方法。