创建一个类库,建立如下类:
复制代码 代码如下:
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)可以实现这个愿望。
标签:
httpModule,执行时间

免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
狼山资源网 Copyright www.pvsay.com

评论“asp.net 通过httpModule计算页面的执行时间”

暂无“asp.net 通过httpModule计算页面的执行时间”评论...

稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!

昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。

这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。

而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?