从 _Layout.cshtml 重定向到另一个页面
Redirect to another page from _Layout.cshtml
如何在 asp.net core razor 的 _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
}
回答
@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");
}
也许是更好的答案
您的问题的用例可能是将未经授权的请求重定向到登录页面。在这种情况下,请使用内置的 razor 页面授权 API。
services
.AddMvc()
.AddRazorPagesOptions(options => {
options.Conventions.AuthorizePage("/Contact");
});
以上代码进入 Startup
> ConfigureServices
方法。
在上面的示例中,API 重定向对 /Contact
的未经授权的请求。
如何在 asp.net core razor 的 _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
}
回答
@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");
}
也许是更好的答案
您的问题的用例可能是将未经授权的请求重定向到登录页面。在这种情况下,请使用内置的 razor 页面授权 API。
services
.AddMvc()
.AddRazorPagesOptions(options => {
options.Conventions.AuthorizePage("/Contact");
});
以上代码进入 Startup
> ConfigureServices
方法。
在上面的示例中,API 重定向对 /Contact
的未经授权的请求。