服务器之家

服务器之家 > 正文

asp.net 通过httpModule计算页面的执行时间

时间:2019-09-12 11:40     来源/作者:asp.net之家

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

复制代码代码如下:


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)可以实现这个愿望。

相关文章

热门资讯

玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分 2019-06-21
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情 2019-06-22
抖音撒撒累累是什么歌 撒撒累累张艺兴歌曲名字
抖音撒撒累累是什么歌 撒撒累累张艺兴歌曲名字 2019-06-05
男生常说24816是什么意思?女生说13579是什么意思?
男生常说24816是什么意思?女生说13579是什么意思? 2019-07-24
超A是什么意思 你好a表达的是什么
超A是什么意思 你好a表达的是什么 2019-06-06
返回顶部