asp.net 通过httpModule计算页面的执行时间
2011-02-19 00:00
831 查看
创建一个类库,建立如下类:
生成后将dll文件copy到bin目录,接着在web.config中注册这个HttpModule:
这样网站的每一个.net页面底部都会显示页面的执行时间了。
不过这样做要小心,因为每个.net页面末尾都会被加上执行时间,包括webservices和ashx页面,以及你可能不是用来直接做页面的.aspx页面(例如你用来输入json数据或者xml数据)。所以,为了保证安全,还必须采取有针对性的方法来避免这种情况的发生。
方法一:在Response.Write方法之前做判断,排除一些不想添加执行时间的页面,可以通过Request.URL来判断;
方法二:不要把执行时间直接添加到页面输出的尾端,而是作为一个http header输出。使用Response.AddHeader(key,value)可以实现这个愿望。
using System; using System.Collections.Generic; using System.Web;//引用web命名空间 using System.Text; namespace TimerHttpModule { public class Class1:IHttpModule//继承IHttpModules { public void Init(HttpApplication application)//实现IHttpModules中的Init事件 { //订阅两个事件 application.BeginRequest +=new EventHandler(application_BeginRequest); application.EndRequest+=new EventHandler(application_EndRequest); } private DateTime starttime; private void application_BeginRequest(object sender, EventArgs e) { //object sender是BeginRequest传递过来的对象 //里面存储的就是HttpApplication实例 //HttpApplication实例里包含HttpContext属性 starttime = DateTime.Now; } private void application_EndRequest(object sender, EventArgs e) { DateTime endtime = DateTime.Now; HttpApplication application = (HttpApplication)sender; HttpContext context = application.Context; context.Response.Write("<p>页面执行时间:" + (endtime - starttime).ToString() + "</p>"); } //必须实现dispose接口 public void Dispose() { } } }
生成后将dll文件copy到bin目录,接着在web.config中注册这个HttpModule:
<configuration> <system.web> <httpModules> <add name="TimerHttpModule" type="TimerHttpModule.Class1"/> </httpModules> </system.web> </configuration>
这样网站的每一个.net页面底部都会显示页面的执行时间了。
不过这样做要小心,因为每个.net页面末尾都会被加上执行时间,包括webservices和ashx页面,以及你可能不是用来直接做页面的.aspx页面(例如你用来输入json数据或者xml数据)。所以,为了保证安全,还必须采取有针对性的方法来避免这种情况的发生。
方法一:在Response.Write方法之前做判断,排除一些不想添加执行时间的页面,可以通过Request.URL来判断;
方法二:不要把执行时间直接添加到页面输出的尾端,而是作为一个http header输出。使用Response.AddHeader(key,value)可以实现这个愿望。
相关文章推荐
- 一:理解ASP.NET的运行机制(例:通过HttpModule来计算页面执行时间)
- 一:理解ASP.NET的运行机制(例:通过HttpModule来计算页面执行时间)
- 一:理解ASP.NET的运行机制(例:通过HttpModule来计算页面执行时间)
- ASP.NET中计算页面执行所耗时间
- asp.net计算页面执行时间
- asp.net计算页面执行时间
- asp.net2中精确计算页面执行时间原来如此简单!
- 在Asp.Net MVC中实现计算页面执行时间及简单流量统计
- asp.net2中精确计算页面执行时间原来如此简单!
- ASP.NET页面执行顺序 (HttpModule,HttpHandler)
- ASP.NET页面执行顺序 (HttpModule,HttpHandler)
- asp.net计算每个页面执行时间的方法
- 计算出你页面执行的时间 ASP.NET
- ASP.NET页面执行顺序 (HttpModule,HttpHandler)
- 在Asp.Net MVC中实现计算页面执行时间及简单流量统计
- asp.net计算每个页面执行时间的方法
- 获取页面执行时间的几种方法(asp.net) (转)
- asp.net页面加载时间计算
- asp.net显示页面执行时间