Molto spesso le nostre applicazioni si trovano ad interagire con degli endpoint HTTP che, se interrogati correttamente, restituiscono i dati che ci interessano sotto forma di JSON. In scenari come questi, il codice che scriviamo è più o meno sempre lo stesso, ovvero:
- Richiesta http;
- Controllo dello status code;
- Lettura della response;
- Conversione del json da semplice stringa ad istanza di un oggetto.
Tralasciando i primi tre step del processo, possiamo affermare che la conversione del JSON da stringa ad una effettiva istanza di classe è l'operazione più tediosa di tutte. Vediamo come possiamo semplificarci la vita tramite un semplice script.
public static class HttpContentExtension { public static async Task<T> ReadAs<T>(this IHttpContent Context) { var content = await Context.ReadAsStringAsync(); return JObject.Parse(content).ToObject<T>(); } }
Lo script sopra riportato aggiunge un extension method alla proprietà Content di tipo IHttpContent contenuta nell'oggetto HttpResponseMessage che, sfruttando la libreria JSON.NET, restituisce una versione tipizzata del body della response http. Ecco riportato un esempio del suo utilizzo.
private async void MakeHttpCall(object sender, RoutedEventArgs e) { HttpClient client = new HttpClient(); HttpResponseMessage response = await client.GetAsync(new Uri("http://api.myendpoint.com/GetOrders")); response.EnsureSuccessStatusCode(); List<Orders> result = await response.Content.ReadAs<List<Orders>>(); }
Come possiamo vedere, utilizziamo i generics per rendere dinamico il nostro metodo. E' chiaro che l'utilizzo di questo accorgimento ci risparmia semplicemente qualche riga di codice, ma permette di rendere più flessibile la nostra logica di accesso ai dati, soprattutto se wrappiamo all'interno di un altro metodo tutte le eventuali chiamate HTTP che effettueremo.
Attenzione: questo particolare metodo funziona con l'HttpClient contenuto all'interno del namespace Windows.Web.Http, ovvero quello incluso di default all'interno di WinRT.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Scenari di test avanzati con ASP.NET Core
GitHub e .NET 6
Serializzare e deserializzare un tipo DateOnly con System.Text.Json
Utilizzare Front Door come CDN di contenuti statici
Blazor + .NET 6 = .NET ovunque
Filtrare le chiamate HTTP ad un App Service in base al servizio Azure
Ottimizzare il json generato dalla serializzazione con System.Text.Json eliminando i valori non necessari
Cambiare a runtime la stringa di connessione di Entity Framework Core
Utilizzare il proxy del WebServer di Angular per simulare chiamate ad API sullo stesso dominio
Utilizzare le Promise in Javascript - seconda parte
Utilizzare una sequence per generare numeri sequenziali con Entity Framework Core
Aggiungere temi custom a Blazor
I più letti di oggi
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Gestire form con più di un pulsante submit in ASP.NET MVC
- Usare TryUpdateModelAsync per aggiornare le entity nelle action di POST in ASP.NET Core MVC
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!