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
Creazione di plugin per Tailwind CSS: espandere le Funzionalità del Framework
Migrare una service connection a workload identity federation in Azure DevOps
Testare l'invio dei messaggi con Event Hubs Data Explorer
Creare una libreria CSS universale: i bottoni
Sfruttare MQTT in cloud e in edge con Azure Event Grid
Hosting di componenti WebAssembly in un'applicazione Blazor static
Come EF 8 ha ottimizzato le query che usano il metodo Contains
Migliorare i tempi di risposta di GPT tramite lo streaming endpoint in ASP.NET Core
Installare le Web App site extension tramite una pipeline di Azure DevOps
Miglioramenti nell'accessibilità con Angular CDK
Evitare la script injection nelle GitHub Actions
Gestione dei nomi con le regole @layer in CSS