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
Creare una custom property in GitHub
Implementare l'infinite scroll con QuickGrid in Blazor Server
Hosting di componenti WebAssembly in un'applicazione Blazor static
Configurare il nome della run di un workflow di GitHub in base al contesto di esecuzione
Generare HTML a runtime a partire da un componente Razor in ASP.NET Core
Change tracking e composition in Entity Framework
Usare i servizi di Azure OpenAI e ChatGPT in ASP.NET Core con Semantic Kernel
Filtrare i dati di una QuickGrid in Blazor con una drop down list
Gestire il colore CSS con HWB
Limitare le richieste lato server con l'interactive routing di Blazor 8
Cambiare la chiave di partizionamento di Azure Cosmos DB
Eliminare una project wiki di Azure DevOps