理解預設路由表
當你建立一個新的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()方法,並使用Null 字元串作為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(); } }}