3

我尝试按照本教程(http://lightswitchhelpwebsite.com/Blog/tabid/61/EntryId/4316/A-Demonstration-of-Simple-Server-side-Blazor-Cookie-Authentication.aspx)进行操作使用 ASP.NET Core 3.0 和 Blazor 框架 v.0.9.0(最新版本)进行 cookie 身份验证的应用程序。对于 IDE,我使用的是 VS 2019 Preview。

作者使用早期版本的 Blazor,但我使用客户端项目而不是 App 遵循教程,因为我认为它们做同样的事情,只是在不同版本的 Blazor 中调用不同。

这是我的结果的回购链接:https ://github.com/SaintMSent/TestBlazorCookieAuth

问题是,它不起作用。如果我转到 localhost:port/login 页面,则会创建 cookie(我检查了 Chrome 开发工具)。如果我去注销页面,它会被删除,所以这部分很好。但该应用程序的其他页面不会加载。如果我从 MainLayout 中删除 Login 组件,一切都加载正常,所以我认为问题在于 Login.cshtml 中的 HttpContext 和 HttpContextAccessor

在此处输入图像描述

这是 Login.cshtml 的样子

@using System.Security.Claims
@using Microsoft.AspNetCore.Http
@page "/login"
@inject IHttpContextAccessor _httpContextAccessor
@inject HttpClient Http
@if (User.Identity.Name != null)
{
    <b>You are logged in as: @User.Identity.Name</b> 
    <a class="ml-md-auto btn btn-primary" 
       href="/logout?returnUrl=/" 
       target="_top">Logout</a>
}
else
{
    <a class="ml-md-auto btn btn-primary" 
       href="/login?returnUrl=/" 
       target="_top">Login</a>
}
@functions {
    private ClaimsPrincipal User;
    protected override void OnInit()
    {
        base.OnInit();
        try
        {
    // Set the user to determine if they are logged in
            User = _httpContextAccessor.HttpContext.User;
        }
        catch { }
    }
}

请帮我弄清楚这里发生了什么。我希望我提供了足够的细节,谢谢。

更新:如果我添加这一行

        services.TryAddSingleton<IHttpContextAccessor, HttpContextAccessor>();

到 Client 项目中的 Startup.cs,一切都在加载,但 _httpContextAccessor.HttpContext.User 始终为空

4

1 回答 1

1

我以奇怪的方式解决了它。我创建了一个名为 AuthController 的控制器并将这些方法添加到其中

    [Route("api/[controller]")]
    public class AuthController : Controller
    {
        [HttpGet]
        [Route("getlogin")]
        public string GetLogin()
        {
            if (User.Identity.IsAuthenticated)
            {
                return $"{User.Identity.Name}";
            }

            return string.Empty;
        }

        [HttpGet]
        [Route("getrole")]
        public string GetRole()
        {
            if (User.Identity.IsAuthenticated)
            {
                if (User.IsInRole("Admin"))
                {
                    return "Admin";
                }

                return "User";
            }

            return string.Empty;
        }
    }

然后我从客户端调用 API,它非常适合我

于 2019-04-28T11:51:43.890 回答