Creazione di route personalizzate (C#)
di Microsoft
Informazioni su come aggiungere route personalizzate a un'applicazione MVC ASP.NET. In questa esercitazione si apprenderà come modificare la tabella di route predefinita nel file Global.asax.
Questa esercitazione illustra come aggiungere una route personalizzata a un'applicazione MVC ASP.NET. Si apprenderà come modificare la tabella di route predefinita nel file Global.asax con una route personalizzata.
Per molte applicazioni ASP.NET MVC semplici, la tabella di route predefinita funzionerà correttamente. Tuttavia, si potrebbe scoprire di avere esigenze di routing specializzate. In tal caso, è possibile creare una route personalizzata.
Si supponga, ad esempio, di creare un'applicazione blog. È possibile gestire le richieste in ingresso simili alle seguenti:
/Archive/12-25-2009
Quando un utente immette questa richiesta, si vuole restituire la voce di blog corrispondente alla data 12/25/2009. Per gestire questo tipo di richiesta, è necessario creare una route personalizzata.
Il file Global.asax nell'elenco 1 contiene una nuova route personalizzata denominata Blog, che gestisce le richieste che hanno un aspetto simile a /Archive/entry date.
Elenco 1 - Global.asax (con route personalizzata)
using System.Web.Mvc;
using System.Web.Routing;
namespace MvcApplication1
{
public class MvcApplication : System.Web.HttpApplication
{
public static void RegisterRoutes(RouteCollection routes)
{
routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
routes.MapRoute(
"Blog", // Route name
"Archive/{entryDate}", // URL with parameters
new { controller = "Archive", action = "Entry" } // Parameter defaults
);
routes.MapRoute(
"Default", // Route name
"{controller}/{action}/{id}", // URL with parameters
new { controller = "Home", action = "Index", id = "" } // Parameter defaults
);
}
protected void Application_Start()
{
RegisterRoutes(RouteTable.Routes);
}
}
}
L'ordine delle route aggiunte alla tabella di route è importante. La nuova route blog personalizzata viene aggiunta prima della route predefinita esistente. Se si è invertito l'ordine, la route predefinita verrà sempre chiamata anziché la route personalizzata.
La route di blog personalizzata corrisponde a qualsiasi richiesta che inizia con /Archive/. Quindi, corrisponde a tutti gli URL seguenti:
/Archive/12-25-2009
/Archive/10-6-2004
/Archive/apple
La route personalizzata esegue il mapping della richiesta in ingresso a un controller denominato Archive e richiama l'azione Entry(). Quando viene chiamato il metodo Entry(), la data di immissione viene passata come parametro denominato entryDate.
È possibile usare la route personalizzata blog con il controller nell'elenco 2.
Listato 2 - ArchiveController.cs
using System;
using System.Web.Mvc;
namespace MvcApplication1.Controllers
{
public class ArchiveController : Controller
{
public string Entry(DateTime entryDate)
{
return "You requested the entry from " + entryDate.ToString();
}
}
}
Si noti che il metodo Entry() in Listing 2 accetta un parametro di tipo DateTime. Il framework MVC è sufficientemente intelligente da convertire automaticamente la data di immissione dall'URL in un valore DateTime. Se il parametro della data di immissione dall'URL non può essere convertito in un valore DateTime, viene generato un errore (vedere la figura 1).
Figura 1 - Errore durante la conversione del parametro
Figura 01: Errore durante la conversione del parametro (fare clic per visualizzare l'immagine a dimensione intera)
Riepilogo
L'obiettivo di questa esercitazione è illustrare come creare una route personalizzata. Si è appreso come aggiungere una route personalizzata alla tabella di route nel file Global.asax che rappresenta le voci di blog. È stato illustrato come eseguire il mapping delle richieste per le voci di blog a un controller denominato ArchiveController e a un'azione controller denominata Entry().