Quando creiamo delle RESTful API, è piuttosto comune avere dei parametri nel path comuni a più action. Immaginiamo per esempio di avere a che fare con un programma di chat. L'endpoint che ci permette di recuperare gli ultimi messaggi di una particolare "Room" potrebbe avere un URL simile al seguente, in cui il path "messages" appare dopo il parametro "5", ossia l'ID della room.
Come possiamo modellare un simile URL nel routing di ASP.NET Core?
Se abbiamo creato un MessagesController, specifico per i messaggi, probabilmente avremo configurato un routing simile al seguente, in cui roomId è un parametro della route a livello di controller - e non di singola action, come più spesso accade.
[Route("rooms/{roomId:int}/[controller]")] [ApiController] public class MessagesController : ControllerBase { ... }
Come possiamo accedere a un tale parametro nel nostro codice?
Una prima possibilità è quella di aggiungere questo parametro al metodo della action:
[HttpGet] public string Get(int roomId) { return $"Room {roomId} has no messages"; }
Questo sistema funziona anche se il parametro - come nel nostro caso - non è presente nel routing specifico della action, ma è definito nel suo parent (il controller). Si tratta di una tecnica molto semplice, che però ha il difetto di duplicare questo parametro ovunque nel codice. Nel caso dovessimo cambiarne il nome o il tipo, dovremmo andare a modificare ogni singola action che lo utilizzi.
Alternativamente, possiamo pensare di esporlo come proprietà nel controller stesso:
[Route("rooms/{roomId:int}/[controller]")] [ApiController] public class MessagesController : ControllerBase { public int RoomId => int.Parse( this.HttpContext.Request.RouteValues["roomId"].ToString()); [HttpGet] public string Get() { return $"Room {this.RoomId} has no messages"; } }
In questo modo, possiamo evitare di includere il parametro nelle singole action, che possono leggerne il valore tramite la proprietà appena creata.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Gestire i dati con Azure Cosmos DB Data Explorer
Change tracking e composition in Entity Framework
Autenticarsi in modo sicuro su Azure tramite GitHub Actions
Path addizionali per gli asset in ASP.NET Core MVC
Configurare lo startup di applicazioni server e client con .NET Aspire
Usare i servizi di Azure OpenAI e ChatGPT in ASP.NET Core con Semantic Kernel
Referenziare un @layer più alto in CSS
Creare gruppi di client per Event Grid MQTT
Disabilitare automaticamente un workflow di GitHub
Eseguire query manipolando liste di tipi semplici con Entity Framework Core
Paginare i risultati con QuickGrid in Blazor
Le novità di Angular: i miglioramenti alla CLI
I più letti di oggi
- Simulare Azure Cosmos DB in locale con Docker
- Utilizzare il metodo Index di LINQ per scorrere una lista sapendo anche l'indice dell'elemento
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- .NET Conference Italia 2024 - Milano
- .NET Conference Italia 2023 - Milano e Online