重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章主要为大家展示了“Controller激活与URL路由的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Controller激活与URL路由的示例分析”这篇文章吧。
创新新互联,凭借10年的成都网站制作、成都网站设计、外贸营销网站建设经验,本着真心·诚心服务的企业理念服务于成都中小企业设计网站有1000+案例。做网站建设,选创新互联。ASP.NET路由系统是HTTP请求抵达服务端的第一道屏障,它根据注册的路由规则对拦截的请求进行匹配并解析包含目标Controller和Action名称的路由信息。而当前ControllerBuilder具有用于激活Controller对象的ControllerFactory,现在看看两者是如何结合起来的。
通过第2章“URL路由”的介绍我们知道,ASP.NET路由系统的核心是一个叫做UrlRoutingModule的HttpModule,路由的实现是它通过注册代表HttpApplication的PostResolveRequestCache事件对HttpHandler的动态映射来实现的。具体来说,它通过以RouteTable的静态属性Routes代表的全局路由表对请求进行匹配并得到一个RouteData对象。RouteData具有一个实现了接口IRouteHandler的属性RouteHandler,通过该属性的GetHttpHandler方法可以得到最终被映射到当前请求的HttpHandler对象。
对于ASP.NET MVC应用来说,RouteData的RouteHandler属性类型为MvcRouteHandler,实现在MvcRouteHandler中的HttpHandler提供机制基本上(不是完全等同)可以通过如下的代码来体现。MvcRouteHandler维护着一个ControllerFactory对象,该对象可以在构造函数中指定,如果没有显示指定则直接通过调用当前ControllerBuilder的GetControllerFactory方法获取。
public class MvcRouteHandler : IRouteHandler
{
private IControllerFactory _controllerFactory;
public MvcRouteHandler(): this(ControllerBuilder.Current
.GetControllerFactory())
{ }
public MvcRouteHandler(IControllerFactory controllerFactory)
{
_controllerFactory = controllerFactory;
}
IHttpHandler IRouteHandler.GetHttpHandler(RequestContext requestContext)
{
string controllerName = (string)requestContext.RouteData
.GetRequiredString("controller");
SessionStateBehavior sessionStateBehavior = _controllerFactory
.GetControllerSessionrequestContext, controllerName);
requestContext.HttpContext.SetSessionStatesessionStateBehavior);< /p>
return new MvcHandler(requestContext);
}
}
在用于提供HttpHandler的GetHttpHandler方法中,除了返回一个实现了IHttpHandler接口的MvcHandler对象之外,还需要对当前HTTP上下文的会话状态行为模式进行设置。具体的实现是:先通过包含在RequestContext的RouteData对象得到Controller的名称,该名称连同RequestContext对象一起传入ControllerFactory的GetControllerSessionBehavior方法得到一个类型为SessionStateBehavior的枚举。最后通过RequestContext得到当前HTTP上下文(实际上是一个HttpContextWrapper对象),并调用其SetSessionStateBehavior方法对会话状态行为进行设置。
通过第2章“URL路由”的介绍我们知道,RouteData中的RouteHandler属性最初来源于对应的路由对象,而当我们调用RouteCollection的扩展方法MapRoute方法时注册的Route对象对应的RouteHandler是一个MvcRouteHandler对象。由于在创建MvcRouteHandler对象时并没有显式指定ControllerFactory,所以通过当前ControllerBuilder的GetControllerFactory方法得到的ControllerFactory默认被使用。
通过当前ControllerBuilder的GetControllerFactory方法得到的ControllerFactory仅仅用于获取会话状态行为模式,而MvcHandler真正将它用于创建Controller。如下的代码片段基本上体现了MvcHandler的定义,它对请求处理的逻辑定义在BeginProce***equest方法中。
public class MvcHandler : IHttpAsyncHandler, IHttpHandler, IRequiresSessionState
{
//其他成员
public RequestContext RequestContext { get; private set; }
public bool IsReusable
{
get { return false; }
}
public MvcHandler(RequestContext requestContext)
{
this.RequestContext = requestContext;
}
IAsyncResult BeginProce***equest(HttpContext context, AsyncCallback cb,
object extraData)
{
IControllerFactory controllerFactory =
ControllerBuilder.Current.GetControllerFactory();
string controllerName =
this.RequestContext.RouteData.GetRequiredString("controller");
IController controller = controllerFactory
.CreateController(this.RequestContext, controllerName);
if (controller is IAsyncController)
{
try
{
//调用BeginExecute/EndExecute方法以异步的方式执行Controller
}
finally
{
controllerFactory.ReleaseController(controller);
}
}
else
{
try
{
//调用Execute方法以异步的方式执行Controller
}
finally
{
controllerFactory.ReleaseController(controller);
}
}
}
}
由于MvcHandler同时实现了IHttpHandler和IHttpAsyncHandler接口,所以它总是以异步的方式被执行(调用BeginProce***equest/EndProce***equest方法)。BeginProce***equest方法通过RequestContext对象得到目标Controller的名称,然后利用当前ControllerBuilder创建的ControllerFactory激活Controller对象。如果Controller类型实现了IAsyncController接口,则以异步的方式执行Controller,否则采用同步执行方式。在被激活Controller对象被执行之后,MvcHandler会调用ControllerFactory的ReleaseController对其进行释放清理工作。
以上是“Controller激活与URL路由的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。