Quando dobbiamo restituire una risposta particolarmente lunga, costituita da una collection di elementi, una delle possibili opzioni è quella di restituirla sotto forma di uno stream. Il beneficio di questo approccio è che un client possa effettuare un download progressivo della risposta, senza dover attendere che il server abbia finito di generarla.
Si tratta, in buona sostanza, di della stessa tecnica utilizzata per simulare push notification dal server verso il client tramite Server Sient Events (SSE).
La buona notizia è che tutto ciò che dobbiamo fare in ASP.NET Core per implementarla, è quella di creare un endpoint Web API che restituisca un IAsyncEnumerable. Per esempio, possiamo modificare il classico WeatherForecast endpoint del template di default di Visual Studio nel modo seguente:
[HttpGet] public async IAsyncEnumerable<WeatherForecast> Get() { for (int i = 0; i < 20; i++) { await Task.Delay(1000); yield return new WeatherForecast { Date = DateTime.Now.AddDays(i), TemperatureC = Random.Shared.Next(-20, 55), Summary = Summaries[Random.Shared.Next(Summaries.Length)] }; } }
Se a questo punto apriamo questo URL dal browser, dovremo attendere circa 20 secondi prima di ottenere la risposta. Questo perché, per default, il browser non attiva lo streaming e attende il completamento della risposta prima di visualizzare qualcosa.
Tuttavia, ci basta aggiungere il seguente header, per cambiare radicalmente il comportamento:
this.Response.ContentType = "text/event-stream";
Ora, visualizzando questo endpoint, potremo vedere come la risposta si componga gradualmente, senza dover attendere che tutti gli elementi siano stati generati.
Questo sistema può essere molto utile combinato al supporto dell'ecosistema .NET per IAsyncEnumerable: per esempio, possiamo utilizzarlo per restituire i risultati di una query di Entity Framework (https://www.linqitalia.com/script/523/Utilizzare-Asynchronous-Stream-Entity-Framework-Core.aspx) man mano che li leggiamo dal database.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Implementare l'infinite scroll con QuickGrid in Blazor Server
Gestire la cancellazione di una richiesta in streaming da Blazor
Autenticarsi in modo sicuro su Azure tramite GitHub Actions
Gestione dell'annidamento delle regole dei layer in CSS
Sviluppare un'interfaccia utente in React con Tailwind CSS e Preline UI
Evitare (o ridurre) il repo-jacking sulle GitHub Actions
Simulare Azure Cosmos DB in locale con Docker
Migliorare l'organizzazione delle risorse con Azure Policy
Effettuare il log delle chiamate a function di GPT in ASP.NET Web API
Inference di dati strutturati da testo con Semantic Kernel e ASP.NET Core Web API
Eseguire operazioni sui blob con Azure Storage Actions
Utilizzare il metodo CountBy di LINQ per semplificare raggruppamenti e i conteggi
I più letti di oggi
- Simulare Azure Cosmos DB in locale con Docker
- Utilizzare il metodo Index di LINQ per scorrere una lista sapendo anche l'indice dell'elemento
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- .NET Conference Italia 2024 - Milano
- .NET Conference Italia 2023 - Milano e Online