29

How can a SignalR JavaScript client detect when a connection with the server is lost?

GEOCHET
  • 21,119
  • 15
  • 74
  • 98
Alexandr
  • 695
  • 2
  • 9
  • 18

7 Answers7

33

A hub has a method disconnect which will allow you to add a callback when disconnection takes place:

myHub.disconnect(function() {
  alert('Server has disconnected');
});

If you aren't using hubs then the code for the disconnect method will help you out:

$(connection).bind("onDisconnect", function (e, data) {
  callback.call(connection);
});

This shows the syntax for hooking onto the onDisconnect event of the underlying connection.

MrBilde
  • 43
  • 6
John Rayner
  • 3,485
  • 21
  • 13
13

If you are using hubs then implement the IDisconnect interface.

public class ChatHub : Hub, IDisconnect
{
    public void Disconnect()
    {
        Debug.WriteLine(Context.ConnectionId + " disconnected");
    }
}

On persistent connections you can override OnDisconnectAsync, (from the SignalR wiki at https://github.com/SignalR/SignalR/wiki/PersistentConnection )

public class MyEndPoint : PersistentConnection 
{
    protected override Task OnDisconnectAsync(string clientId) 
    {
        return Connection.Broadcast("Client " + clientId + " disconncted");   
    }
}
MatteKarla
  • 2,707
  • 1
  • 20
  • 29
8

The SignalR 2.0 way of doing this is like so:

$.connection.hub.disconnected(function () {
    console.log('Connection disconnected')
});

http://www.asp.net/signalr/overview/signalr-20/hubs-api/hubs-api-guide-javascript-client#connectionlifetime

gholmes
  • 101
  • 1
  • 7
8

This worked for me using "@aspnet/signalr": "^1.0.0" npm package

const connection = new signalr.HubConnectionBuilder()
    .withUrl('url')
    .configureLogging(signalr.LogLevel.Information)
    .build()

connection.onclose(() => {
   // close logic goes here
})
Ross Jones
  • 973
  • 7
  • 20
6

Starting with SignalR v0.5.1 it works this way:

$.connection.hub.stateChanged(function (change) {
    if (change.newState === $.signalR.connectionState.reconnecting) {
        console.log("liveFeed is reconnecting!");
    }
    else if (change.newState === $.signalR.connectionState.connected) {
        console.log("liveFeed is connected!");
    }
});

For more details check this website:

http://weblogs.asp.net/davidfowler/archive/2012/06/10/signalr-0-5-1-released.aspx

bp74
  • 418
  • 4
  • 11
3

The below, worked for me:

var connection = $.hubConnection('signalrConnectionUrl');

connection.disconnected(function() {
    console.log('Connection disconnected');
});

I'm using version: 2.1.2

See the following link for reference: Link

martinmose
  • 443
  • 8
  • 12
1

The provided answers will no longer work. This is the new way to stop/disconnect connections.

myHub.stop().then(() => {
  alert('Server has disconnected');
});
Alireza
  • 2,319
  • 2
  • 23
  • 35