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
Eseguire query manipolando liste di tipi semplici con Entity Framework Core
Inizializzare i container in Azure Container Apps
Utilizzare HiLo per ottimizzare le insert in un database con Entity Framework
Utilizzare le collection expression in C#
Gestire errori funzionali tramite exception in ASP.NET Core Web API
Sviluppare un'interfaccia utente in React con Tailwind CSS e Preline UI
Eseguire attività basate su eventi con Azure Container Jobs
Creare form tipizzati con Angular
Definire stili a livello di libreria in Angular
Specificare il versioning nel path degli URL in ASP.NET Web API
Hosting di componenti WebAssembly in un'applicazione Blazor static
Esportare ed analizzare le issue di GitHub con la CLI e GraphQL
I più letti di oggi
- Utilizzare Docker Compose con Azure App Service
- Utilizzare QuickGrid di Blazor con Entity Framework
- Modernizzare le applicazioni WPF e Windows Forms con Blazor
- ASP 3 per esempi
- annunciato #netstandard 2.1. .NET Core lo supporterà a partire da #netcore3, così come le prossime versione di #xamarin, #mono e #unity.il supporto per #netfx 4.8, invece, non ci sarà. https://aspit.co/bq2