signalr不在特定的isp网络上工作

sha*_*haf 11 asp.net asp.net-mvc-4 signalr

我正在使用ASP.NET MVC 4和SignalR 2.1.1.我的网站适用于所有浏览器中的大多数用户,但只有特定isp网络上的特定用户才会出现错误.

错误是这样的:

The connection to ws://domain.com/signalr/connect?transport=webSockets&clientProtocol=1.4&connectionToken=78ZpJ007jmlLSBbVzDVbfpYahHsveD3x8%2Bc5PC9h%2FgeOz5zNgE8SaKWaQAasGNLe%2BvJeI6ux6IqW0E8WQWqP6Ps%2FXjc8WPbG7G47oHSxRSx7nVj0leVa1DdXzEXnLQ%2BA&connectionData=%5B%7B%22name%22%3A%22homehub%22%7D%5D&tid=4 was interrupted while the page was loading.
Run Code Online (Sandbox Code Playgroud)

对于收到此错误的相同用户,使用其他网络(同一浏览器/计算机/手机)登录Internet可解决此问题.

到目前为止,我只看到有关此错误的问题,将问题指向浏览器,但在我的情况下,使用具有不同网络的相同浏览器可以解决问题.

任何人都知道如何解决这个问题吗?

更新1: 我注意到客户端方法确实有效,这是服务器方法不起作用.

我是什么意思?:

我有一个在线用户列表,当用户进入和退出网站时,会调用更新用户名列表的信号器客户端方法:

hub.client.addOnlineMember = function (member) {
    var newMember = addMember(member);
    memberList.append(newMember);
};
hub.client.removeOnlineMember = function (member) {
    var newMemberId = '#' + member;
    $(memberListName + ' ' + newMemberId).remove();
};
Run Code Online (Sandbox Code Playgroud)

但是,当尝试从服务器加载消息时,它的功能不起作用:

$('#LoadMore').click(function () {
        hub.server.loadTopics(page);
    });
Run Code Online (Sandbox Code Playgroud)

更新2: 我添加了日志记录:

$.connection.hub.logging = true;
Run Code Online (Sandbox Code Playgroud)

以下是调查结果:

The connection to ws://domain.com/signalr/connect?transport=webSockets&clientProtocol=1.4&connectionToken=rR8%2BSK%2BC%2FtuzPqIGKgPrUNORzBz2kP0WUmXJsURP70Zsj6RK1fOi5tUN1UGEQPntGwoEvwinMkPCXRTyliLwzfLoOBl%2BkCWoBAkAqIFYaDVk3X1MG8dQERl8Or%2F4%2Filp&connectionData=%5B%7B%22name%22%3A%22hub%22%7D%5D&tid=6 was interrupted while the page was loading. jquery.signalr-2.1.1.min.js:8
Synchronous XMLHttpRequest on the main thread is deprecated because of its detrimental effects to the end user's experience. For more help http://xhr.spec.whatwg.org/ jquery-2.1.1.min.js:4
"[16:21:50] SignalR: Stopping connection." jquery.signalr-2.1.1.min.js:8
"[16:21:50] SignalR: Closing the Websocket." jquery.signalr-2.1.1.min.js:8
no element found abort:1
"[16:21:50] SignalR: Fired ajax abort async = false." jquery.signalr-2.1.1.min.js:8
"[16:21:50] SignalR: Stopping the monitoring of the keep alive." jquery.signalr-2.1.1.min.js:8
"[16:21:51] SignalR: Client subscribed to hub 'hub'." jquery.signalr-2.1.1.min.js:8
"[16:21:51] SignalR: Negotiating with '/signalr/negotiate?clientProtocol=1.4&connectionData=%5B%7B%22name%22%3A%22hub%22%7D%5D'." jquery.signalr-2.1.1.min.js:8
"[16:21:51] SignalR: Connecting to websocket endpoint 'ws://domain.com/signalr/connect?transport=webSockets&clientProtocol=1.4&connectionToken=bkg5ksXTUdzl9GrShmLqEyUbeG9SMDBaiccbH2prQ4t1mPmoOutKqj9gvgkd9vveTnIKhK0cMHYZ8NOrS4pemaLmwOb5TmNJzGEiPAUXrknuIhxtUSqmNmL255MIFdwc&connectionData=%5B%7B%22name%22%3A%22hub%22%7D%5D&tid=2'." jquery.signalr-2.1.1.min.js:8
"[16:21:51] SignalR: Websocket opened." jquery.signalr-2.1.1.min.js:8
"[16:21:51] SignalR: webSockets transport selected. Initiating start request." jquery.signalr-2.1.1.min.js:8
"[16:21:51] SignalR: The start request succeeded. Transitioning to the connected state." jquery.signalr-2.1.1.min.js:8
"[16:21:51] SignalR: Now monitoring keep alive with a warning timeout of 13333.333333333332 and a connection lost timeout of 20000." jquery.signalr-2.1.1.min.js:8
"[16:23:05] SignalR: Triggering client hub event 'addOnlineMember' on hub 'hub'." jquery.signalr-2.1.1.min.js:8
"[16:23:25] SignalR: Triggering client hub event 'removeOnlineMember' on hub 'hub'." jquery.signalr-2.1.1.min.js:8
"[16:23:42] SignalR: Invoking hub.LoadTopics" jquery.signalr-2.1.1.min.js:8
Run Code Online (Sandbox Code Playgroud)

如您所见,客户端方法非常有效.正在调用服务器方法但没有任何反应.

在工作的isp网络上记录信号器:

"[17:03:40] SignalR: Invoking hub.LoadTopics" jquery.signalr-2.1.1.min.js:8
"[17:03:41] SignalR: Triggering client hub event 'addTopicToHome' on hub 'hub'." jquery.signalr-2.1.1.min.js:8
"[17:03:41] SignalR: Triggering client hub event 'incrementPage' on hub 'hub'." jquery.signalr-2.1.1.min.js:8
"[17:03:41] SignalR: Invoked hub.LoadTopics" jquery.signalr-2.1.1.min.js:8
Run Code Online (Sandbox Code Playgroud)

更新3:

将我的项目上传到IIS 7.5服务器后,该代码适用于所有ISP网络.由于IIS 7.5不支持Websockets,因此服务器发送事件,长轮询和永久帧(取决于浏览器)等协议已成功启动.但是,我不知道IIS 8服务器在实现websockets不起作用时没有启动工作协议的原因,这是信号器的作用,不是吗?

我与我的托管服务提供商联系,他们认为该问题与服务器上不受支持的SSL密钥有关.这个SSL问题仍然没有被他们修复,所以没有办法确定这是真正的问题.你觉得这可能是吗?

无论如何,仍然没有成功找到答案..请帮助.

sha*_*haf 3

好吧,已经过去这么久了,我希望现在能得到帮助,但没关系,我已经成功了。

第一的:

Jabbr 信号员频道的人员建议我尝试使用 SSL 浏览网站,希望能解决问题。恐怕我没有机会检查这一点:(但是如果你们中的任何人遇到同样的问题并使用 SSL 方法来解决它,我绝对会喜欢在这里讨论它!

以及我的回答:

我正在获取用户 IP 并测试它是否位于任何有问题的 ISP 子网中。如果是,我将向视图传递一个参数,例如: bool disableWebsockets = True/False; 如果这是真的,我将向 signalr 传递一个不包含 websocket 的传输协议列表。如果为 false - 该列表确实包含 Websocket。

就是这样。

function signalrTransportList(wsState) {
    if (disableWebsockets == "False") {
        var list = ['webSockets', 'serverSentEvents', 'longPolling', 'foreverFrame'];
    }
    else {
        var list = ['serverSentEvents', 'longPolling', 'foreverFrame'];
    }

    return list;
}

...
...

$.connection.hub.start({ transport: signalrTransportList(wsTransport) })
Run Code Online (Sandbox Code Playgroud)