我们正在尝试将 SignalR 与 Angular 2 和 TypeScript 一起使用。看来我的客户端代码不起作用,尤其是建立连接(没有生成的代理)
我使用 SignalR 遵循 Angular 2 TypeScript,但我没有包含 SignalR/Hubs 脚本路径,因为我没有自动生成的代理,因为我没有看到为我创建的任何自动生成的代理类。还参考了 SignalR 文档使用 Javascript 编写的代码
我们使用 windows 身份验证和 Visual Studio 2015、Windows 7、IIS Express
我收到这个错误
协商请求期间出错。
集线器类
public class ServerRefreshHub : Hub
{
public ServerRefreshHub()
{
}
public override Task OnConnected()
{
//It seems hub is not connected as client code fails
}
public static void NotifyUsers()
{
IHubContext context = GlobalHost.ConnectionManager.GetHubContext<ServerRefreshHub>();
context.Clients.All.MessageFromServer("Hello");
}
}
Asp.Net WebAPI 启动
public partial class Startup
{
public void Configuration(IAppBuilder app)
{
app.Map(
"/signalr",
map =>
{
var hubConfiguration = new HubConfiguration {
EnableDetailedErrors = true };
map.RunSignalR(hubConfiguration);
});
}
}
角码
declare var $: any;
@Injectable()
export class ServerNotifier {
private connection: any;
private proxy: any;
constructor() {
this.connection = $.hubConnection();
this.proxy = this.connection.createHubProxy('userCacheRefreshHub');
this.proxy.on('MessageFromServer', (message: string) =>
this.onMessageFromServer(message));
this.connection.start().done((data: any) => {
console.log('Now connected ' + data.transport.name + ', connection ID= ' + data.id);
}).fail((error: any) => {
console.log('Could not connect ' + error);
});
}
private onMessageFromServer(message: string) {
}
}
包.Json
"@types/jquery": "2.0.47",
"@types/signalr": "^2.2.35",
"signalr": "^2.2.2"
笔记:
"@types/jquery": "^3.2.16" 引入了最新的打字稿更新,我开始遇到更多问题,所以我只为打字而降级
在控制台中,我看到这个请求的 URL 的200响应代码http://localhost:58965/signalr/negotiate?clientProtocol=1.5&connectionData=%5B%7B%22name%22%3A%22serverrefreshhub%22%7D%5D&_=1509976299819