• 欢迎访问开心洋葱网站,在线教程,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站,欢迎加入开心洋葱 QQ群
  • 为方便开心洋葱网用户,开心洋葱官网已经开启复制功能!
  • 欢迎访问开心洋葱网站,手机也能访问哦~欢迎加入开心洋葱多维思维学习平台 QQ群
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏开心洋葱吧~~~~~~~~~~~~~!
  • 由于近期流量激增,小站的ECS没能经的起亲们的访问,本站依然没有盈利,如果各位看如果觉着文字不错,还请看官给小站打个赏~~~~~~~~~~~~~!

asp.net 如何使用httpModule计算页面的执行时间

C# 水墨上仙 2715次浏览

有时候我们想检测一下网页的执行效率。记录下开始请求时的时间和页面执行完毕后的时间点,这段时间差就是页面的执行时间了。要实现这个功能,通过HttpModule来实现是最方便而且准确的。

创建一个类库,建立如下类:&nbsp

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:&nbsp

<configuration> 
<system.web> 
<httpModules> 
<add name="TimerHttpModule" type="TimerHttpModule.Class1"/> 
</httpModules> 
</system.web> 
</configuration> 

这样网站的每一个.net页面底部都会显示页面的执行时间了。&nbsp
不过这样做要小心,因为每个.net页面末尾都会被加上执行时间,包括webservices和ashx页面,以及你可能不是用来直接做页面的.aspx页面(例如你用来输入json数据或者xml数据)。所以,为了保证安全,还必须采取有针对性的方法来避免这种情况的发生。&nbsp
方法一:在Response.Write方法之前做判断,排除一些不想添加执行时间的页面,可以通过Request.URL来判断;&nbsp
方法二:不要把执行时间直接添加到页面输出的尾端,而是作为一个http&nbspheader输出。使用Response.AddHeader(key,value)可以实现这个愿望。


开心洋葱 , 版权所有丨如未注明 , 均为原创丨未经授权请勿修改 , 转载请注明asp.net 如何使用httpModule计算页面的执行时间
喜欢 (0)
加载中……