理解預設路由表
當你建立一個新的ASP.NET MVC應用程式時,應用程式已經被配置為使用ASP.NET路由。ASP.NET路由在兩個地方設定。
第一點,在你的應用程式Web配置檔案(Web.config檔案)中啟用ASP.NET路由。在配置檔案中有四個節點與路由有關:sytem.web.httpModules節,system.web.httpHandlers節,system.webserver.modules節,以及system.webserver.handlers節。特別要小心不要刪除了這些節點,因為沒有它們路由將不能工作。
第二點,也是更為重要的一點,在應用程式的Global.asax檔案中建立了一個路由表。Global.asax檔案是一個特殊的檔案,它包含了作用於ASP.NET應用程式生命週期事件的事件處理程式。路由表在Application Start事件期間建立。
ASP.NET MVC應用程式的預設Global.asax檔案內容如下:
namespace MvcApplication { // Note: For instructions on enabling IIS6 or IIS7 classic mode, // visit http://go.microsoft.com/?LinkId=9394801 public class MvcApplication : System.Web.HttpApplication { public static void RegisterRoutes(RouteCollection routes) { routes.IgnoreRoute("{resource}.axd/{*pathInfo}"); 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); RouteTable.Routes.RouteExistingFiles = false; RouteMonitor.RouteDebugger.RewriteRoutesForTesting(RouteTable.Routes); } } }
當一個MVC應用程式首次執行時,會呼叫Application_Start()方法。這個方法隨後呼叫了RegisterRoutes()方法。RegisterRoutes()方法建立了路由表。
預設的路由表包含了一個路由(名叫Default)。Default路由將URL的第一部分對映到控制器名,URL的第二部分對映到控制器動作,第三個部分對映到一個叫做id的引數。
假設你在瀏覽器的位址列輸入了下面的URL:
/Home/Index/3
預設的路由將這個URL對映為下面的引數:
Controller = Home
Action = Index
id = 3
當你請求URL /Home/Index/3時,將會執行下面的程式碼:
HomeController.Index(3)
Default路由包含了所有三個引數的預設值。如果你不提供控制器,那麼控制器引數預設值為Home。如果你不提供動作,動作引數預設為值Index。最後,如果你不提供id,id引數預設為空字串。
Default路由是如何將URL對映到控制器動作的
設想你在瀏覽器位址列輸入了下面的URL:
/Home
由於Default路由引數的預設值,輸入這個URL將會呼叫HomeController類的Index()方法。
using System.Web.Mvc; namespace MvcApplication1.Controllers { [HandleError] public class HomeController : Controller { public ActionResult Index(string id) { return View(); } } }
HomeController類包含了一個叫做Index()的方法,它接受一個叫做Id的引數。URL /Home將會導致呼叫Index()方法,並使用空字串作為Id引數的值。
出於MVC框架呼叫控制器動作的方式,URL /Home也匹配以下中HomeController類的Index()方法。
using System.Web.Mvc; namespace MvcApplication1.Controllers { [HandleError] public class HomeController : Controller { public ActionResult Index() { return View(); } } }
以上程式碼的Index()方法不接受任何的引數。URL /Home將會導致呼叫這個Index()方法。URL /Home/Index/3也會呼叫這個方法(Id被忽略)。
URL /Home也會匹配以下程式碼HomeController類的Index()方法
using System.Web.Mvc; namespace MvcApplication1.Controllers { [HandleError] public class HomeController : Controller { public ActionResult Index(int? id) { return View(); } } }
Index()方法擁有一個整數引數。因為這個引數是一個可空引數(可以擁有Null值),因此可以呼叫Index()而不會引發錯誤。
最後,使用URL /Home 呼叫以下程式碼中的Index()方法將會引發一個異常,因為Id引數並非一個可空引數。如果你試圖呼叫Index()方法,那麼你將會獲得一個錯誤。
using System.Web.Mvc; namespace MvcApplication1.Controllers { [HandleError] public class HomeController : Controller { public ActionResult Index(int id) { return View(); } } }