如何在asp.net核心剃须刀中重定向到_layout.cshtm页面中的另一页面。
我正在执行验证,并且用户已登录,否则将被重定向到另一个页面。
@using Microsoft.AspNetCore.Identity
@using CronoParque.Model
@inject SignInManager<ApplicationUser> SignInManager
@inject UserManager<ApplicationUser> UserManager
@if (SignInManager.IsSignedIn(User))
{
<form asp-controller="Account" asp-action="Logout" method="post" id="logoutForm" class="navbar-right">
<ul class="nav navbar-nav navbar-right">
<li>
<a asp-page="/Account/Manage/Index" title="Manage">Ola @UserManager.GetUserName(User)!</a>
</li>
<li>
<button type="submit" class="btn btn-link navbar-btn navbar-link">Sair</button>
</li>
</ul>
</form>
}
else
{
// targeting here
}
答案 0 :(得分:0)
@if (SignInManager.IsSignedIn(User))
{
// normal stuff
}
else if (!Context.Request.Path.ToString().Contains("/About"))
{
// If we aren't processing a request for the target page,
// then redirect to it.
Context.Response.Redirect("/About");
}
您问题的用例可能是将未经授权的请求重定向到登录页面。在这种情况下,请使用内置的剃刀页面授权API。
services
.AddMvc()
.AddRazorPagesOptions(options => {
options.Conventions.AuthorizePage("/Contact");
});
上面的代码进入了Startup
> ConfigureServices
方法。
在上面的示例中,API重定向了对/Contact
的未授权请求。