3.8 KiB
title | author | description | monikerRange | ms.author | ms.custom | ms.date | uid |
---|---|---|---|---|---|---|---|
ASP.NET Core SignalR .NET Client | tdykstra | Information about the ASP.NET Core SignalR .NET Client | >= aspnetcore-2.1 | tdykstra | mvc | 09/10/2018 | signalr/dotnet-client |
ASP.NET Core SignalR .NET Client
The ASP.NET Core SignalR .NET client library lets you communicate with SignalR hubs from .NET apps.
[!NOTE] Xamarin has special requirements for Visual Studio version. For more information, see SignalR Client 2.1.1 in Xamarin.
View or download sample code (how to download)
The code sample in this article is a WPF app that uses the ASP.NET Core SignalR .NET client.
Install the SignalR .NET client package
The Microsoft.AspNetCore.SignalR.Client
package is needed for .NET clients to connect to SignalR hubs. To install the client library, run the following command in the Package Manager Console window:
Install-Package Microsoft.AspNetCore.SignalR.Client
Connect to a hub
To establish a connection, create a HubConnectionBuilder
and call Build
. The hub URL, protocol, transport type, log level, headers, and other options can be configured while building a connection. Configure any required options by inserting any of the HubConnectionBuilder
methods into Build
. Start the connection with StartAsync
.
[!code-csharpBuild hub connection]
Handle lost connection
Use the xref:Microsoft.AspNetCore.SignalR.Client.HubConnection.Closed event to respond to a lost connection. For example, you might want to automate reconnection.
The Closed
event requires a delegate that returns a Task
, which allows async code to run without using async void
. To satisfy the delegate signature in a Closed
event handler that runs synchronously, return Task.CompletedTask
:
connection.Closed += (error) => {
// Do your close logic.
return Task.CompletedTask;
};
The main reason for the async support is so you can restart the connection. Starting a connection is an async action.
In a Closed
handler that restarts the connection, consider waiting for some random delay to prevent overloading the server, as shown in the following example:
[!code-csharpUse Closed event handler to automate reconnection]
Call hub methods from client
InvokeAsync
calls methods on the hub. Pass the hub method name and any arguments defined in the hub method to InvokeAsync
. SignalR is asynchronous, so use async
and await
when making the calls.
[!code-csharpInvokeAsync method]
Call client methods from hub
Define methods the hub calls using connection.On
after building, but before starting the connection.
[!code-csharpDefine client methods]
The preceding code in connection.On
runs when server-side code calls it using the SendAsync
method.
[!code-csharpCall client method]
Error handling and logging
Handle errors with a try-catch statement. Inspect the Exception
object to determine the proper action to take after an error occurs.
[!code-csharpLogging]