ASP.NET SignalR, quando utilizzato nell'ambito di un'applicazione web, sfrutta un client JavaScript per stabilire una connessione bidirezionale con il server. Il comportamento di default dei browser è quello di abilitare le chiamate solo sullo stesso dominio della pagina visualizzata.
Ciò impedisce, per esempio, di referenziare una stesso hub da applicazioni differenti, ospitate su domini differenti. Questo scenario può essere comunque gestito attivando il supporto a CORS (Cross Origin Resource Sharing) sul middleware Owin. Per farlo dobbiamo innanzitutto referenziare con NuGet il package Microsoft.Owin.Cors:
A questo punto, sul file Startup.cs in cui configuriamo ASP.NET SignalR, dobbiamo modificare il mapping come nel codice in basso:
public void Configuration(IAppBuilder app) { // ... app.Map("/signalr", x => { x.UseCors(CorsOptions.AllowAll); var hubConfig = new HubConfiguration() { EnableJSONP = true }; x.RunSignalR(hubConfig); }); }
Entrando nel dettaglio, la prima istruzione abilita CORS sull'URL relativo /signalr, permettendo l'acceso a qualsiasi client, a prescindere dall'URL, grazie all'opzione CorsOptions.AllowAll. Successivamente, per migliorare la compatibilità con le versioni più vecchie di Internet Explorer, abbiamo attivato anche il supporto a JSONP. L'istruzione RunSignalR finale, esegue ASP.NET SignalR sull'indirizzo specificato.
Per testare questo scenario, possiamo per esempio effettuare il deploy del sito su un Windows Azure Web Site e poi impostare, sulla nostra copia locale, la connessione verso 'indirizzo remoto:
$.connection.hub.url = 'http:/' + '/corstest.azurewebsites.net/signalr'; $.connection.hub.start().done(function () { // ... }
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Sfruttare lo stream rendering per le pagine statiche di Blazor 8
Assegnare un valore di default a un parametro di una lambda in C#
Load test di ASP.NET Core con k6
Evitare la command injection in un workflow di GitHub
Usare il versioning con i controller di ASP.NET Core Web API
Code scanning e advanced security con Azure DevOps
Eseguire query verso tipi non mappati in Entity Framework Core
Accesso sicuro ai secrets attraverso i file in Azure Container Apps
Utilizzare la libreria Benchmark.NET per misurare le performance
Sfruttare i KeyedService in un'applicazione Blazor in .NET 8
Implementare l'infinite scroll con QuickGrid in Blazor Server
Utilizzare il trigger SQL con le Azure Function