ASP.Net 请求响应流程简述
一、浏览器请求页面的简单流程
当浏览器请求静态页面时,会发送请求给服务器软件,服务器软件直接去找对应的静态页面,并返回给浏览器。
当浏览器请求动态页面时,服务器软件收到请求,发现处理不了.aspx文件,就去映射表当中根据后缀名找对应的处理程序(aspnet_isapi.dll),这个处理程序实现了服务器软件提供的接口,即服务器软件通过接口调用了这个处理程序当中的方法。aspnet_isapi.dll会将请求转交给.Net Framework,由它处理动态页面,创建页面对象,生成相应报文,响应给浏览器。
当服务器接收到浏览器的动态页面请求时,去网站的程序集中找对应的类,通过反射的方式创建类的对象,并运行ProcessRequest方法处理用户的需求,最后通过Write方法输出响应数据。
执行Write时,会把数据放入缓存区,页面执行完毕后一次性返还给浏览器。
二、一般处理程序的IHttpHandler接口
服务器接收请求,要创建页面对象的时候,发现每一个文件都是一个类,它不知道如何去调用方法创建页面,于是就需要一个中间处理——将页面类的对象转成一个接口IHttpHandler类型,然后通过调用接口中的方法来实现处理。
一般处理程序是一个实现了IHttpHandler特殊接口的类,凡是实现了这个接口的类,都能作为一个外部请求的目标程序。
如果被请求的类没有实现这个接口,在转换的时候就会出错,提示没有实现IHttpHandler接口。所以,一般处理程序里的方法,实际上是实现了IHttpHandler中的方法。
三、一般处理程序细节
IHttpHandler是重要的接口,context封装了所有浏览器发来的请求报文,ProcessRequest方法表示页面被访问时调用这个方法里的代码段,是个入口。Context.Response是对输出的封装,ContextType是响应报文中的ContextType值,是响应输出的方式。
IsReusable是IHttpHandler中的另一个方法,设置页面是否可以重用,以减少多次访问时Web服务器的压力。
四、详细请求流程
服务器接收到用户请求,aspnet_isapi.dll将请求移交给Application Domain,它会间接调用HttpRuntime的静态方法处理用户的请求。
首先,分析请求报文,并把请求报文封装成HttpWorkerRequest对象,之后拆解请求报文,将各个字段封装位HttpRequest对象(这个对象包含QueryString和Form方法)。
HttpRequest对象和HttpResponse对象等,共同组成了HttpContext对象。
HttpApplicationFactory类查找Application池中有没有现成可用的HttpApplication对象,如果有就直接拿来用,如果没有,就创建一个。HttpApplication对象中有ProcessRequest方法,这个方法有HttpContext对象。正好拿刚才的来用。
HttpApplication对象进入请求管道,先后执行19个委托事件,在第8个事件时创建被请求页面的对象,在第11和12个事件之间执行被创建对象的ProcessRequest方法。
五、WebForm的页面生命周期
在请求管道的第11个事件执行被创建页面类的PeocessRequest方法后,会调用BuildControlsTree方法进入页面的生命周期。
在页面生命周期中会连续调用一连串的事件,其中一个Render方法会去遍历整个控件树,生成对应的HTML代码,最后组合成为整个页面的HTML代码返还给浏览器。