我觉得我要么错过了 SignalR 服务的重点,要么我的架构错了。
使用 Azure SignalR 服务,我可以让前端到前端的通信正常工作;
启动.cs
public void Configuration(IAppBuilder app)
{
ConfigureAuth(app);
ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls12;
app.MapAzureSignalR(this.GetType().FullName);
}
集线器.cs
private void BroadcastMessage(string message)
{
Clients.All.broadcastMessage(message);
}
索引.html
hubName.client.broadcastMessage = function (message) {
alert(message);
};
$('#btn').click(function () {
hubName.server.broadcastMessage("Hello World");
});
这很好,当我需要后端触发消息时,我正在使用以下内容;
函数.cs
HubConnection signalr = new HubConnection("http://localhost:57690/");
IHubProxy hub = null;
if (signalr.State == ConnectionState.Disconnected)
{
hub = signalr.CreateHubProxy(hubName);
signalr.Start().Wait();
}
hub.Invoke(functionName, args);
signalr.Stop();
虽然这可行,但它让我想知道我是否实施错了,因为这http://localhost:57690/signalr/hubs
对任何来源的帖子都是开放的。
在前端,我必须提供Endpoint=https://appName.service.signalr.net;AccessKey=xxxxx
设置,但不能从后端提供。
除了安全问题外,这让我质疑 SignalR 服务在这方面的目的。
当然,必须有更好的方法从后端调用信号器。
非常感谢,
汤姆