Share via


Integrating SignalR with ASP.NET Web API

In this article let’s see how we can integrate and trigger SignalR with ASP.NET Web API. Let’s start off by creating a solution and adding an ASP.NET Web API project and empty ASP.NET project. Let’s set the API project’s Project URL to {web_app_project_url}/api, so it will run under the Web App Project URL. And we need to modify the DefaultApi route to remove explicit “api” part as follows.

config.Routes.MapHttpRoute(
   name: "DefaultApi",
   routeTemplate: "{controller}/{id}",
   defaults: new { id = RouteParameter.Optional }
);

Now let’s install SignalR NuGet package to the ASP.NET Web API project. You can use either NuGet Package Manager and Package Manager Console. Here we are using Package Manager Console by running Install-Package Microsoft.AspNet.SignalR.

https://lh3.googleusercontent.com/-7zDM46ZXX3Q/V2jHtGscagI/AAAAAAAAD94/ah_PVXptZCQ/image_thumb%25255B10%25255D.png?imgmax=800
Install-Package Microsoft.AspNet.SignalR

Now open up the Startup.cs in the Web API project and bootstrap SignalR as follows.

using Microsoft.Owin;
using Owin;
 
[assembly: OwinStartup(typeof(AspNetWebApiSignalRDemo.WebApi.Startup))]
 
namespace AspNetWebApiSignalRDemo.WebApi
{
    public partial class Startup
    {
        public void Configuration(IAppBuilder app)
        {
            ConfigureAuth(app);
            app.MapSignalR();
        }
    }
}

Now let’s create a folder inside Web API project named “Hubs” and add a SignalR Hub Class. Let's name it as “NotificationHub”.

https://lh3.googleusercontent.com/-tm3kjDSYUn0/V2jHvOMvMyI/AAAAAAAAD-I/T4OIewDV6BU/image_thumb%25255B11%25255D.png?imgmax=800
SignalR Hub Class

The created file will contain a Hello() method, and let's just leave it as it is.

Now let’s move into the empty web app project. For the sake of demonstration, let's use AngularJS to bootstrap the web app project. For that let's install following dependencies using Bower.

https://lh3.googleusercontent.com/-M_579OhxcOw/V2jHwrwCb1I/AAAAAAAAD-Y/YWIDWKkX8o4/image_thumb%25255B5%25255D.png?imgmax=800
Bower dependencies

index.html

<!DOCTYPE html>
<html ng-app="AspNetWebApiSignalRDemo">
 
<head>
    <script src="bower_components/jquery/dist/jquery.min.js"></script>
    <script src="bower_components/signalr/jquery.signalR.min.js"></script>
    <script src="bower_components/angular/angular.min.js"></script>
    <script src="api/signalr/hubs"></script>
    <script src="app.js"></script>
 
    <title>ASP.NET Web API and SignalR Demo</title>
    <meta charset="utf-8" />
</head>
<body>
    <div ng-controller="AppController">
        
    </div>
</body>
</html>

app.js

'use strict';
 
angular.module("AspNetWebApiSignalRDemo", [])
 
.service("SignalrService", function () {
    var notificationHubProxy = null;
 
    this.initialize = function () {
        $.connection.hub.logging = true;
        notificationHubProxy = $.connection.notificationHub;
 
        notificationHubProxy.client.hello = function () {
            console.log("Hello from ASP.NET Web API");
        };
 
        $.connection.hub.start().done(function () {
            console.log("started");
        }).fail(function (result) {
            console.log(result);
        });
    };
})
 
.controller("AppController", ["SignalrService", function (SignalrService) {
    SignalrService.initialize();
}]);

Now if you run the solution, you will see that SignalR is making a successful connection with our NotificationHub in the ASP.NET Web API project.

https://lh3.googleusercontent.com/-dQqm-mQuGNA/V2jHxgN9FDI/AAAAAAAAD-o/hEyUCQrPw20/image_thumb%25255B12%25255D.png?imgmax=800
SignalR connected successfully

To make sure whether we can invoke client side methods from the Web API project, let’s use the NotificationHub from an API action. For that let's modify the NotificationHub class adding a static method as follows.

using Microsoft.AspNet.SignalR;
 
namespace AspNetWebApiSignalRDemo.WebApi.Hubs
{
    public class NotificationHub : Hub
    {
        private static IHubContext hubContext = GlobalHost.ConnectionManager.GetHubContext<NotificationHub>(); 
        public void Hello()
        {
            Clients.All.hello();
        }
 
        public static void SayHello()
        {
            hubContext.Clients.All.hello();
        }
    }
}

And let’s just modify the Get() action in ValuesController as follows. Please note that we are attributing it with [AllowAnonymous], so we can access directly from the browser without authenticating.

[AllowAnonymous]
public IEnumerable<string> Get()
{
    NotificationHub.SayHello();
 
    return new string[] { "value1", "value2" };
}

And now if you invoke the /api/values from the browser, you will see that Web API is triggering client hub event "hello".

https://lh3.googleusercontent.com/-aILpYGyjYhY/V2jHzUBc5GI/AAAAAAAAD-4/8S9Cvi5UNq0/image_thumb%25255B13%25255D.png?imgmax=800
Web API + SignalR

Download

Happy Coding.