我刚刚更新了一些SignalR引用,但为了允许通用类型的Hub Hub<T>
,情况有所改变。在现有的示例和文档中,例如:
我们有一个静态类,通过以下机制保存对客户端的引用:
public class StockTicker()
{
private readonly static Lazy<StockTicker> _instance = new Lazy<StockTicker>(
() => new StockTicker(GlobalHost.ConnectionManager.GetHubContext<StockTickerHub>().Clients));
IHubConnectionContext Clients {get;set;}
private StockTicker(IHubConnectionContext clients)
{
Clients = clients;
}
}
因此检查静态引用,如果为null,则它将到达:
GlobalHost.ConnectionManager.GetHubContext<StockTickerHub>().Clients
创建实例并通过构造函数提供客户端。
所以这就是它以前的工作方式,而且上面的网址确实是这样的。但现在使用Hub<T>
,构造函数中需要稍作更改:
private StockTicker(IHubConnectionContext<dynamic> clients)
{
Clients = clients;
}
现在我的问题是如何进一步扩展这一点,以便我的StockTicker版本可以为x类型的客户端提供强类型属性。
IHubConnectionContext<StockTickerHub> Clients {get;set;}
private StockTicker(IHubConnectionContext<dynamic> clients)
{
Clients = clients; // Fails, wont compile
}
通过维护强类型引用,我可以调用强类型方法等。
答案 0 :(得分:27)
GetHubContext现在有一个新的重载,它带有两个通用参数。第一个是像之前一样的Hub类型,但第二个通用参数是TClient(它是Hub<T>
中的T)。
假设StockTickerHub定义如下:
public class TypedDemoHub : Hub<IClient>
然后
GlobalHost.ConnectionManager.GetHubContext<StockTickerHub>().Clients
变为
GlobalHost.ConnectionManager.GetHubContext<StockTickerHub, IClient>().Clients
GetHubContext的新重载返回的类型为IHubContext<IClient>
,Clients属性为IHubConnectionContext<IClient>
,而不是IHubConnectionContext<dynamic>
或IHubConnectionContext<StockTickerHub>
。
答案 1 :(得分:2)
答案 2 :(得分:0)
答案 3 :(得分:0)
在 .NET Core Web App 中,您可以像这样
注入强类型的signalR集线器上下文
public interface IClient
{
Task ReceiveMessage(string message);
}
public class DevicesHub : Hub<IClient>
{
}
public class HomeController : ControllerBase
{
private readonly IHubContext<DevicesHub, IClient> _devicesHub;
public HomeController(IHubContext<DevicesHub, IClient> devicesHub)
{
_devicesHub = devicesHub;
}
[HttpGet]
public IEnumerable<string> Get()
{
_devicesHub.Clients
.All
.ReceiveMessage("Message from devices.");
return new string[] { "value1", "value2" };
}
}