HTTP请求管道事件BeginRequest和EndRequest
这是一个测试示例,代码如下:
using System; using System.Collections.Generic; using System.Linq; using System.Web; namespace WebApplication1 { public class MyHttpModule:IHttpModule { public void Init(HttpApplication context) { context.EndRequest += context_EndRequest; context.BeginRequest += context_BeginRequest; } void context_BeginRequest( object sender, EventArgs e) { HttpApplication app = (HttpApplication)sender; HttpContext _context = app.Context; _context.Response.Write( "<script type=\"text/javascript\">alert('1');document.write('context_BeginRequest');</script>" ); //_context.Response.End(); //string mimeStr = _context.Response.ContentType; //_context.Response.Write("context_BeginRequest-mime:" + mimeStr); } void context_EndRequest( object sender, EventArgs e) { HttpApplication app = (HttpApplication)sender; HttpContext _context = app.Context; _context.Response.Write( "<script type=\"text/javascript\">alert('2');document.write('context_EndRequest')</script>" ); //_context.Response.End(); //string mimeStr = _context.Response.ContentType; //_context.Response.Write("context_EndRequest-mime:" + mimeStr); } public void Dispose() { } } } |
运行输出:
查看源码:
结论:
BeginRequest是在给客户端输出HTML内容前调用;EndRequest是在给客户端输出HTML内容后调用;
页面的Page_Load事件是请求进入页面首先执行的,然后才输出HTML内容给客户端;
扩展内容(HttpApplication的处理管道19个事件):
1.BeginRequest:asp.net开始处理请求的第一个事件,表示处理的开始。
2.AuthenticateRequest:验证请求,一般用来取得请求的用户信息。
3.PostAuthenticateRequest:已经获取请求的用户信息。
4.AuthorizeRequest:授权,一般用来检查用户的请求是否获得权限。
5.PostAuthorizeRequest:用户请求已经获得授权。
6.ResolveRequestCache:获取以前处理缓存的处理结果,如果以前缓存过,那么,不用再进行请求的处理工作,直接返回缓存的结果。
7.PostResolveRequestCache:已经完成缓存的处理工作。
8.PostMapRequestHandler:已经根据用户的请求,创建了请求的处理器对象。
9.AcquireRequestState:取得请求的状态,一般用于session
10.PostAcquireRequestState:已经获得了session
11.PreRequestHandlerExecute:准备执行处理程序。
12.PostRequestHandlerExecute:已经执行了处理程序
13.ReleaseRequestState:释放请求的状态。
14.PostReleaseRequestState:已经释放了请求的状态。
15.UpdateRequestCache:更新缓存。
16.PostUpdateRequestCache:已经更新了缓存。
17.LogRequest:请求的日志操作
18.PostLogRequest:已经完成请求的日志操作。
19.EndRequest:本次请求处理完成。
图解:
参考资料:
http://www.cnblogs.com/xhwy/archive/2012/05/20/2510178.html
https://www.cnblogs.com/wupeiqi/archive/2013/03/05/2944354.html
https://www.cnblogs.com/yuanyuan/archive/2010/11/15/1877709.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端