ASP.NET MVC Route 由浅入深系列之十五:ASP.
下面我们学习一下ASP.NET 的内部机理,说实在的,很多做.NET的同学,包括我,从来没有也很少去关注ASP.NET里面的东西,至于它是怎样去运作的,都是把它当作一个黒盒,一问三不知,其实这样是不好的。只会用,而不知其所以然,都头来就只真的是一个码农,注定不能走更远。
好了,闲话少说,了解ASP.NET的内部机理,对我们学习MVC有什么好处呢? 其他的先不说,首先我们可以明白MVC框架的整体处理流程,其次对于路由的学习也很有裨益,特别是在自定义路由,比方,老板要你把网址统统变为大写,例如:http://localhost/news/list变为:http://localhost/NEWS/LISTS,这该如何用代码实现呢?或者为了搜索引擎的SEO,要把http://localhost/Schwarzenegger变为http://localhost/施瓦辛格 ,这个又应该怎样来处理呢?
答案是先从学习ASP.NET的内部机理开始,请参见MSDN文档:<<ASP.NET Application Life Cycle Overview for IIS 5.0 and 6.0>>和<<ASP.NET Application Life Cycle Overview for IIS 7.0>>.这两篇文章大同小异,只是涉及到IIS的不同版本,个别地方有点差异,但主要的涉及到ASP.NET 处理的流程都是一样,下面我们来具体看看它的生命周期:
Satege1
用户发起请求,这个容易理解,有可能是WEB FORM请求一个.ASPX页面,或者是MVC请求一个CONTROLLER和ACTION.
Satege2
IIS收到用户请求,将它交给ASP.NET(我这个说话不准确,其实中间还有通过IIS的ISAPI调用ASP.NET ISAPI,这才是真正处理ASP.NET 资源的API),接着一个名为ApplicationManager的类会创建一个应用程序域(AppDomain为应用程序提供了隔离).
Satege3
在应用程序域创建后,接着ASP.NET创建核心类,如HttpContext,HttpResponse,HttpRequest等。
Satege4
在第4个阶段,HttpApplication会用来建立后,真正来处理请求。可以从下图看得出,如果是有3个不同的用户发起请求,那么就有3个对应的HttpApplication实例化来响应用户的请求。
Satege5
接下来进去ASP.NET的管道(pipeline)处理阶段,这个阶段有很多事件(Event),具体可以参考:MSDN <<HttpApplication Class>>,我们可以通过注入(Injection)定制我们感兴趣的事件。
这个阶段有两个非常非常重要的概念,就是Http Module和Http Handler。前者Http Module通过注入(Injection)到HttpApplication的各个事件,对请求进行处理或者定制,具体在MVC路由匹配里是由 System.Web.Routing下的UrlRoutingModule类来进行注入,下面是它的一段极为关键的代码,用户获取路由数据:(下篇文章会专门解释)
后者Http Handler是用来真正用来处理请求的类,例如WEB FORM中处理ASPX的就是PageRouteHandler类,而MVC里用来处理请求的类就是MvcHandler,下文是其极为关键的一段代码,用来实例化Controller:
看得出来,它在UrlRoutingModule里获得路由数据的基础上,利用工厂模式实例化一个名为controllerName的Controller,下面是关键代码:
string controllerName = RequestContext.RouteData.GetRequiredString("controller");
// Instantiate the controller and call Execute
factory = ControllerBuilder.GetControllerFactory();
controller = factory.CreateController(RequestContext, controllerName);
下文将会Module和Http Handler做详细的分享和介绍,敬请期待!
请关注我吧