我们将整个ASP.NET MVC框架划分为若干个子系统,那么针对请求上下文激活目标Controller对象的子系统被我们成为Controller激活系统。在正式讨论Controller对象具体是如何被创建爱之前,我们先来看看Controller激活系统在ASP.NET MVC中的总体设计,了解一下组成该子系统的一些基本的组件,以及它们对应的接口或者抽象类是什么。
目录
一、Controller
二、 ControllerFactory
三、ControllerBuilder
实例演示:如何提升命名空间的优先级
针对Area的路由对象的命名空间
四、 Controller的激活与URL路由
一、Controller
我们知道作为Controller的类型直接或者间接实现了IController接口。如下面的代码片断所示,IController接口仅仅包含一个参数类型为RequestContext的Execute方法。当一个Controller对象被激活之后,核心的操作就是根据请求上下文解析出目标Action方法,并通过Model绑定机制从请求上下文中提取相应的数据映射为方法的参数并最终执行Action方法。所有的这些操作都是调用这个Execute方法来执行的。
- public interface IController
- {
- void Execute(RequestContext requestContext);
定义在IController接口中的Execute是以同步的方式执行的。为了支持以异步方式对请求的处理,IController接口的异步版本System.Web.Mvc.IAsyncController被定义出来。如下面的代码片断所示,实现了IAsyncController接口的异步Controller的执行通过BeginExecute/EndExecute方法组合来完成。
- public interface IAsyncController : IController
- {
- IAsyncResult BeginExecute(RequestContext requestContext, AsyncCallback callback, object state);
- void EndExecute(IAsyncResult asyncResult);
- }
抽象类ControllerBase实现了IController接口,它具有如下几个重要的属性。TemplateData、ViewBag和ViewData用于存储从Controller向View传递的数据或者变量。其中TemplateData和ViewData具有基于字典的数据结构,Key和Value分别表示变量的名称和值,所不同的前者用于存储基于当前HTTP上下文的变量(在完成当前请求后,存储的数据会被回收)。ViewBag和ViewData具有相同的作用,甚至对应着相同的数据存储,它们之间的不同之处在于前者是一个动态对象,我们可以为其指定任意属性。
- public abstract class ControllerBase : IController
- {
- //其他成员
- public ControllerContext ControllerContext { get; set; }
- public TempDataDictionary TempData { get; set; }
- public object ViewBag { [return: Dynamic] get; }
- public ViewDataDictionary ViewData { get; set; }
在ASP.NET MVC中我们会陆续遇到一系列的上下文(Context)对象,之前我们已经对表示请求上下文的RequestContext(HttpContext + RouteData)进行了详细的介绍,现在我们来介绍另一个具有如下定义的上下文类型ControllerContext。
- public class ControllerContext
- {
- //其他成员
- public ControllerContext();
- public ControllerContext(RequestContext requestContext, ControllerBase controller);
- public ControllerContext(HttpContextBase httpContext,
- RouteData routeData, ControllerBase controller);
- public virtual ControllerBase Controller { get; set; }
- public RequestContext RequestContext { get; set; }
- public virtual HttpContextBase HttpContext { get; set; }
- public virtual RouteData RouteData { get; set; }
- }
顾