手机
当前位置:查字典教程网 >编程开发 >asp.net教程 >asp.net 通过httpModule计算页面的执行时间
asp.net 通过httpModule计算页面的执行时间
摘要:创建一个类库,建立如下类:复制代码代码如下:usingSystem;usingSystem.Collections.Generic;usin...

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

复制代码 代码如下:

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 Google样式分页控件

asp.net 按字节检查包含全半角的文字

asp.net WebForm页面间传值方法

asp.net 2.0多语言网站解决方法

asp.net 设置GridView的选中行

asp.net ext treepanel 动态加载XML的实现方法

asp.net Hashtable 遍历写法

asp.net保存远程图片的代码

asp.net 半角全角转化工具

Asp.net中的页面乱码的问题

精品推荐
分类导航