从_Layout.cshtml重定向到另一个页面

时间:2018-07-18 19:59:55

标签: asp.net-mvc asp.net-core asp.net-core-2.0 razor-pages

如何在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
}

1 个答案:

答案 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的未授权请求。

另请参阅:https://docs.microsoft.com/en-us/aspnet/core/security/authorization/razor-pages-authorization?view=aspnetcore-2.1#require-authorization-to-access-a-page