Passare oggetti complessi nell'ambito di una chiamata GET non è sempre una buona idea, e spesso può essere indice di una cattiva implementazione delle convenzioni REST. Esistono tuttavia sempre delle eccezioni: pensiamo al caso in cui, tramite il nostro endpoint in GET, vogliamo fornire dei filtri di ricerca, per esempio indicando una serie di valori tramite cui filtrare la chiave. In altri termini, vogliamo scrivere una action come quella seguenteç
public IEnumerable<Customer> Get(int[] id) { return db.Customers .Where(x => id.Any(y => y == x.Id); }
ASP.NET Web API supporta nativamente questo scenario e l'unico requisito è specificare che l'array deve essere prelevato dall'URI invece che dal body. Per farlo è sufficiente modificare il metodo in questo modo, inserendo l'attributo FromUri:
public IEnumerable<Customer> Get([FromUri]int[] id) { // ... }
La ragione risiede nel fatto che, per default, i tipi complessi vengono ricercati nel body della richiesta, cosa che ovviamente non ha senso nell'ambito di una richiesta di tipo GET.
A questo punto potremo specificare i valori nell'URL semplicemente ripetendo più volte la chiave id nell'url:
http://localhost:11334/api/customers/?id=1&id=2&id=3
Purtroppo questo formato della querystring può risultare non comodissimo da gestire. In un prossimo script vedremo come renderlo un po' più semplice e meno verboso.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Usare il colore CSS per migliorare lo stile della pagina
Utilizzare gRPC su App Service di Azure
Managed deployment strategy in Azure DevOps
Usare le navigation property in QuickGrid di Blazor
Configurare e gestire sidecar container in Azure App Service
Utilizzare una qualunque lista per i parametri di tipo params in C#
Generare un hash con SHA-3 in .NET
Utilizzare QuickGrid di Blazor con Entity Framework
Usare i settings di serializzazione/deserializzazione di System.Text.Json di ASP.NET all'interno di un'applicazione non web
Combinare Container Queries e Media Queries
Creare una libreria CSS universale - Rotazione degli elementi
Migliorare i tempi di risposta di GPT tramite lo streaming endpoint in ASP.NET Core