Nel precedente script ci siamo occupati di come definire le regole di routing tramite template all'interno dell'applicazione. Come avveniva anche nella precedente versione di ASP.NET MVC, anche in ASP.NET Core questo è solo uno dei possibili approcci.
L'alternativa più comune è quella di sfruttare l'attribute routing, ossia di decorare tramite specifici attributi le nostre action e controller per specificare a quali URL debbano essere associati.
Immaginiamo di avere il controller e la action seguenti:
public class AnotherController : Controller { [Route("ByAttribute/Index/{id:int}")] public IActionResult Index(int? id) { return View(id); } }
L'attributo Route specifica l'intero template di URL a cui questa action dovrà rispondere. Come possiamo notare, con una sintassi molto simile a quella utilizzata per la definizione dei route template, abbiamo anche indicato che nella route è presente un parametro e che esso dovrà essere di tipo int.
L'elenco completo dei constraint utilizzabili è contenuto in questa pagina della documentazione:
https://docs.microsoft.com/en-us/aspnet/core/fundamentals/routing#route-constraint-reference
Se tutte le action che afferiscono a un controller hanno una parte dell'URL in comune, possiamo specificare questa porzione a livello di controller, e indicare sulla action eventuali altri path:
[Route("ByAttribute")] public class AnotherController : Controller { [Route("{id:int}")] [Route("Index/{id:int}")] public IActionResult Index(int? id) { return View(id); } }
In questo esempio abbiamo associato due path, /ByAttribute/{id} e /ByAttribute/Index/{id} alla action, definendo in pratica Index come action di default.
Una action può riscrivere la route definita a livello di controller anteponendo il carattere "/":
[Route("ByAttribute")] public class AnotherController : Controller { // risponde a http://localhost/TotallyDifferent [Route("/TotallyDifferent")] public IActionResult Index() { return View(id); } }
Se dobbiamo specificare anche l'HTTP Verb a cui la action deve rispondere, per esempio il POST, possiamo indicarlo assieme alla route utilizzando l'attributo HttpPost:
[Route("ByAttribute")] public class AnotherController : Controller { // risponde a http://localhost/TotallyDifferent [HttpPost("Index/{id:int}")] public IActionResult Index(int? id, MyModel model) { return View(id); } }
Un ultima nota riguarda la generazione dei link tramite tag-helper che, ovviamente, rispetterà le definizioni di routing che abbiamo impostato:
<!-- Genera un link a /ByAttribute/Index/{id} --> <a asp-action="Index" asp-controller="Another" asp-route-id="123">Test</a>
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Potenziare Azure AI Search con la ricerca vettoriale
Utilizzare domini personalizzati gestiti automaticamente con Azure Container Apps
Effettuare chiamate con versioning da Blazor ad ASP.NET Core
Ottimizzare il mapping di liste di tipi semplici con Entity Framework Core
Utilizzare HiLo per ottimizzare le insert in un database con Entity Framework
Utilizzare database e servizi con gli add-on di Container App
.NET Conference Italia 2023
Gestire undefined e partial nelle reactive forms di Angular
Verificare la provenienza di un commit tramite le GitHub Actions
Miglioramenti nell'accessibilità con Angular CDK
Utilizzare politiche di resiliency con Azure Container App
Evitare la script injection nelle GitHub Actions
I più letti di oggi
- 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
- Steel Style CheckBox per Silverlight 4.0
- Supporto ai tipi DateOnly e TimeOnly in Entity Framework Core
- Speciale Windows Store app: costruire app con WinRT per Windows 8