MVC中的路由是MVC声明周期的一部分,所以我们先要普及一下知识——MVC的生命周期。
这是根据调试,以及上网查看资料,画出的生命周期图,用户在浏览器的网址中输入相应的URL,然后通过路由机制解析URL,去调用相应的控制器,执行相应的方法,再将相应的页面结果返回到的、浏览器上,以供用户浏览。(为了简化理解,中级的一部分过程已经省略。)
而MVC中的路由就起到了一个解析URL的作用。将用户输入的URL地址中的控制器名称和Action名称解析出来,寻找相应的页面显示给用户。
在调试MVC例子的时候,程序每次执行都是从Global.asax中的Application_Start方法中启动执行。
1、注册路由,将新建的Route对象添加到RouteTable对象中,RouteTable对象用于存储所有的路由规则。
protected void Application_Start() { RegisterRoutes(RouteTable.Routes); }
2、执行路由选择
public static void RegisterRoutes(RouteCollection routes) { routes.IgnoreRoute("{resource}.axd/{*pathInfo}"); routes.MapRoute( "Default", "{controller}/{action}/{id}", new { controller = "Home",action = "Index", id = "" } ); }
上述代码中的Routes对象有两个方法,一个是IgnoreRoute,另一个是MapRoute。其中,IgnoreRoute方法是用来定义不需要路由规则处理的网址,指定后缀名为.axd等格式的网址不通过MVC执行。
而MapRoute方法,就是用来识别URL的,其中Default是路由的名称,后面的“{controller}/{action}/{id}”就是我们需要解析出来的东西,一个是controller名称,Action名称,以及Id名称。不写的话,controller默认的是Home,action默认的是Index,而id默认为空。
例如,localhost/Home/Index,这个URL地址,通过路由解析将去执行HomeController里面的Index方法,将相应的页面传递给用户。
一个东西,看得多了,代码调试的多了,思路就清晰了,虽然简单了解了一些MVC中的路由机制,但是中间的Http请求什么的还没有搞清楚,接下来继续探索。