码迷,mamicode.com
首页 > Web开发 > 详细

mvc请求过程总结-前篇

时间:2015-05-16 23:16:52      阅读:164      评论:0      收藏:0      [点我收藏+]

标签:

前言

      最近在思考一个问题,我的学习方法一般主要是看博客来学习新东西,但是光看,基本也没总结过,所以经常会出现这样的问题,某个知识点我知道,但是就是不能很好的表达出来,很简单的东西往往都不知道如何简短精炼的阐述清楚。所以我想到应该每天抑或是经常性的总结近期学到的知识,这样既可以巩固知识又可以提高语言的组织能力。

MVC的请求过程

     有些比较细节的地方直接忽略了,我主要摸索它的大概轨迹

     首先从客户端发出请求开始,iis接受请求,找到web应用程序运行的工作者进程,如果进程不存在,则创建的新的工作进程,在其初始化的时候,aspnet_isapi.dll被加载,isapi启动CLR以及相关应用程序域和相关web应用的初始化。随后一个特殊的运行时isapiRuntime被加载,它将接管http请求。

    接管http请求的ISAPIRutime会首先创建isapiWorkRequset对象来封装当前http请求,随后将此对象传递给HttpRuntime,至此,请求到达了asp.net管道,接着就执行HttpRuntime.PR方法,其中主要做了两件事。

    1.根据httpWorkRequset创建httpContext对象,此对象同于表示当前请求的上下文。

    2.根据httpApplicationFatory创建或获取现有的httpApplication对象

        httpApplicationFatory工厂初始化的时候,从asp.net维护的httpApplication对象池中获取HttpApplition对象,如果池子中没有对象,将通过global文件编译的类型通过反射获取httpApplication

      在httpApplication初始化的时候,asp.net会根据配置文件加载并初始化HttpModule对象,httpApplication对象主要是在处理http请求不同阶段会触发不同的事件,而httpmodule的意义在于通过注册httpApplication管道中的事件,将所需的操作注入整个请求流程。

       在mvc中,UrlRoutingModule注册了httpApplication请求处理阶段的第8个事件中(表示用户已获得缓存内容),在这个事件响应方法中主要是根据当前请求生成HttpContextWrapper对象以及获取根据请求URL从路由表匹配出对应的RouteData对象,接着根据当前请求从RouteData中获取mvcHanler,并将它映射到当前请求。此后http请求将交给mvcHttphadler接管。

       当事件流动到真正开始处理当前请求时,将执行mvc的Httphadler.PR方法,此后的事情就是激活Controller和执行对应的Action方法对请求做出最后响应。其中关于Controller和Action执行的细节,改天再进行探索。

        本人刚学mvc不久,见识短浅,表达能力有限,理解或描述不好的地方请多多指教! 

mvc请求过程总结-前篇

标签:

原文地址:http://www.cnblogs.com/JaggerMan/p/4508768.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!