4

使用 .NET Core 2.1 和 VS2017 预览版 2,我创建了一个简单的 Web 服务器,其中包含“作为 UI 的身份”,如此处所述,然后在此之后添加了一个 SignalR聊天

特别是我有:

app.UseAuthentication();
app.UseSignalR((options) => {
    options.MapHub<MyHub>("/hubs/myhub");
});

..

[Authorize]
public class MyHub : Hub

..

"iisSettings": {
  "windowsAuthentication": false,
  "anonymousAuthentication": true,
     "iisExpress": {
     "applicationUrl": "http://localhost:5000",
     "sslPort": 0

我启动带浏览器的调试器,注册用户并登录,然后转到http://localhost:5000/SignalRtest(我使用 signalr.js 的剃须刀页面)并验证聊天是否正常。

我现在尝试创建一个 .NET Core 控制台应用聊天客户端:

class Program
{
    public static async Task SetupSignalRHubAsync()
    {
        var hubConnection = new HubConnectionBuilder()
                    .WithUrl("http://localhost:5000/hubs/myhub")
                    .Build();

        await hubConnection.StartAsync();
        await hubConnection.SendAsync("Send", "consoleapp");
    }

    public static void Main(string[] args)
    {
        SetupSignalRHubAsync().Wait();
    }
}

我的问题是我不知道如何验证这个客户端?

编辑:

(来自https://github.com/aspnet/SignalR/issues/2455

“它在浏览器中工作的原因是因为浏览器在您登录时有一个 Cookie,因此它会在 SignalR 发出请求时自动发送它。要在 .NET 客户端中执行类似的操作,您必须调用 REST API在可以设置 cookie 的服务器上,从 HttpClient 舀取 cookie,然后在对 .WithUrl 的调用中提供它,如下所示:

var loginCookie = /* get the cookie */
var hubConnection = new HubConnectionBuilder()
    .WithUrl("http://localhost:5000/hubs/myhub", options => {
        options.Cookies.Add(loginCookie);
    })
    .Build();

我现在悬赏这个问题,希望得到一个解决方案,展示如何使用“身份作为 UI”的 .NET Core 2.1 Web 应用 SignalR 服务器对 .NET Core 2.1 SignalR 控制台客户端进行身份验证。我需要从服务器获取 cookie,然后将其添加到 SignalR HubConnectionBuilder(现在有一个 WithCookie 方法)。

请注意,我不是在寻找像 IdentityServer 这样的第三方解决方案谢谢!

4

1 回答 1

2

我确实最终让它像这样工作:

在服务器上,我搭建了 Login 脚手架,然后在 Login.cshtml.cs 中添加了

[AllowAnonymous]
[IgnoreAntiforgeryToken(Order = 1001)]
public class LoginModel : PageModel

那就是我在登录时不需要防伪令牌(无论如何这都没有意义)

客户端代码是这样的:

HttpClientHandler handler = new HttpClientHandler();
CookieContainer cookies = new CookieContainer();
handler.CookieContainer = cookies;
HttpClient client = new HttpClient(handler);

var uri = new Uri("http://localhost:5000/Identity/Account/Login");
string jsonInString = "Input.Email=myemail&Input.Password=mypassword&Input.RememberMe=false";
HttpResponseMessage response = await client.PostAsync(uri, new StringContent(jsonInString, System.Text.Encoding.UTF8, "application/x-www-form-urlencoded"));
var responseCookies = cookies.GetCookies(uri);
var authCookie = responseCookies[".AspNetCore.Identity.Application"];

var hubConnection = new HubConnectionBuilder()
        .WithUrl("http://localhost:5000/hubs/myhub", options =>
        {
            options.Cookies.Add(authCookie);
        })
        .Build();

await hubConnection.StartAsync();
await hubConnection.SendAsync("Send", "hello!");

(当然密码将在部署的其他地方)

于 2018-06-08T23:52:50.057 回答