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代码返还给浏览器。