HTTP运行期与页面执行模型 【摘自文野的一天一点学aspnet之基础概念】

一个完整的HTTP请求在ASP.NET 的处理过程如下:

HttpRequest  ---> inetinfo.exe --->ASPNET_ISAPI.dll --->Http Pipeline ---> ASPNET_WP.exe
--->HttpRuntime ---> HttpApplication Factory ---> HttpApplication ---> HttpModule ---> HttpHandler Factory ---> HttpHandler ---> HttpHandler.ProcessRequest()

页面执行模型

页面执行模型由页面HTTP处理程序工厂(HttpHandler Factory)开始,它注册HTTP运行期以为所有.aspx文件处理请求。页面处理程序工厂负责创建一个Page对象的实例,这是将最终处理请求所生成响应结果的HTTP处理程序。

首先页面处理程序工厂尝试在与请求的.aspx文件相关的.NET高速缓存内查找以前编译过的页面类。当查找失败时,就像第一次请求一样,处理程序工厂将读取和解析文件,并创建一棵解析树(parse tree)。解析树类似于控件树,但是并不包含控件,解析树包含称为控件生成器(control builder)的对象实例。控件生成器包含了在解析过程期间收集的相关控件信息。然后通过Page指令中的Language attribute,用与页面相关的语言把解析树转变为代码。然后,页面处理程序工厂调用适当的编译程序,动态地编译从Page中得到的类,页面处理程序工厂还将新建的类放置到ASP.NET调整缓存中,并且把高速缓存记录和文件相关性关联起来。文件相关性监视.aspx文件做出的变化,并保证任何变化都自动地使高速缓存记录无效,在下次请求时这些记录将再次解析修改过的文件。

原文地址:https://www.cnblogs.com/songshuqun/p/763643.html