如何在ASP.NET站点中实现对用户请求的监控
2009-04-17 23:21
435 查看
今天在讲课的间隙,有朋友问到这个问题:一个站点中,如果希望监控到用户请求的地址,不管是他通过在地址栏输入地址,还是通过点击链接来请求的。
要做这样的事情,其实重点是要理解APS.NET的HttpModule的机制。我们可以编写一个自定义的HttpModule,专门地监控这个行为。
为此,请按照下面的步骤来做
1. 定义一个新的HttpModule
public class RequestMonitorModule:IHttpModule
{
#region IHttpModule 成员 public void Dispose()
{
} public void Init(HttpApplication context)
{
context.BeginRequest += new EventHandler(context_BeginRequest);
} void context_BeginRequest(object sender, EventArgs e)
{
HttpApplication app = (HttpApplication)sender;
string url = app.Request.Url.AbsolutePath; string path = app.Server.MapPath("Log.txt"); FileStream fs = new FileStream(path, FileMode.Append);
StreamWriter sw = new StreamWriter(fs);
sw.WriteLine(string.Format("地址:{0},时间{1}", url, DateTime.Now.ToString())); sw.Close();
/// } #endregion
} 这里的关键就在于实现IHttpModule接口,并在Init方法中为application的BeginRequest事件绑定一个事件处理程序。
2.注册该Module
<httpModules>
<add name="MyModule" type="MyWebApplication.RequestMonitorModule"/>
</httpModules> 3. 然后就可以进行测试了
输出的日志文件大致如下
地址:/test/default.aspx,时间2009-4-17 17:56:39
地址:/test/Product.aspx,时间2009-4-17 17:56:44
地址:/test/Product.aspx,时间2009-4-17 17:57:22
地址:/test/default.aspx,时间2009-4-17 18:00:42
地址:/test/Test.htm,时间2009-4-17 18:00:47
【注意】如果在VS里面调试的话,htm页面也能被监控到的,但如果真的部署到了IIS,就没有了。是因为在IIS上面,htm页面是不会交给ASP.NET引擎来处理的。那么怎么样改变这个行为呢?我们可以修改站点的配置
点击“配置”
点击“添加”
要做这样的事情,其实重点是要理解APS.NET的HttpModule的机制。我们可以编写一个自定义的HttpModule,专门地监控这个行为。
为此,请按照下面的步骤来做
1. 定义一个新的HttpModule
public class RequestMonitorModule:IHttpModule
{
#region IHttpModule 成员 public void Dispose()
{
} public void Init(HttpApplication context)
{
context.BeginRequest += new EventHandler(context_BeginRequest);
} void context_BeginRequest(object sender, EventArgs e)
{
HttpApplication app = (HttpApplication)sender;
string url = app.Request.Url.AbsolutePath; string path = app.Server.MapPath("Log.txt"); FileStream fs = new FileStream(path, FileMode.Append);
StreamWriter sw = new StreamWriter(fs);
sw.WriteLine(string.Format("地址:{0},时间{1}", url, DateTime.Now.ToString())); sw.Close();
/// } #endregion
} 这里的关键就在于实现IHttpModule接口,并在Init方法中为application的BeginRequest事件绑定一个事件处理程序。
2.注册该Module
<httpModules>
<add name="MyModule" type="MyWebApplication.RequestMonitorModule"/>
</httpModules> 3. 然后就可以进行测试了
输出的日志文件大致如下
地址:/test/default.aspx,时间2009-4-17 17:56:39
地址:/test/Product.aspx,时间2009-4-17 17:56:44
地址:/test/Product.aspx,时间2009-4-17 17:57:22
地址:/test/default.aspx,时间2009-4-17 18:00:42
地址:/test/Test.htm,时间2009-4-17 18:00:47
【注意】如果在VS里面调试的话,htm页面也能被监控到的,但如果真的部署到了IIS,就没有了。是因为在IIS上面,htm页面是不会交给ASP.NET引擎来处理的。那么怎么样改变这个行为呢?我们可以修改站点的配置
点击“配置”
点击“添加”
相关文章推荐
- 如何在ASP.NET站点中实现对用户请求的监控
- [PHP/.NET]如何把PHP站点用户登录会话传递到ASP.NET站点
- ASP.Net中用C#实现站点计数器用户控件
- [PHP/.NET]如何把PHP站点用户登录会话传递到ASP.NET站点
- ASP.Net中用C#实现站点计数器用户控件
- 如何用ASP.NET实现bosh模拟http双向长连接请求
- 如何使用反射技术实现ASP.NET国际化站点
- [PHP/.NET]如何把PHP站点用户登录会话传递到ASP.NET站点
- [PHP/.NET]如何把PHP站点用户登录会话传递到ASP.NET站点
- 如何在 ASP.NET 应用程序中实现模拟用户身份(在ASP.NET中以管理员身份运行网站)
- asp.net中用C#实现站点计数器用户控件[转]
- ASP.NET如何实现在用户注册时为用户指定角色
- asp.net如何实现跟踪检查用户知否查看了邮件。
- [PHP/.NET]如何把PHP站点用户登录会话传递到ASP.NET站点
- ASP.NET WebApi服务接口如何防止重复请求实现HTTP幂等性(八)
- asp.net中用C#实现站点计数器用户控件
- ASP.NET 2.0实现防止同一用户同时登陆
- ASP.NET实现用户在线检测的类源码[转&收藏]
- ASP.NET SignalR 与 LayIM2.0 配合轻松实现Web聊天室(四) 之 用户搜索(Elasticsearch),加好友流程(1)。
- 【C#】对异步请求处理程序IHttpAsyncHandler的理解和分享一个易用性封装 【手记】走近科学之为什么明明实现了IEnumerable<T>的类型却不能调用LINQ扩展方法 【手记】手机网页弹出层后屏蔽底层的滑动响应 【手记】ASP.NET提示“未能创建类型”处理 【Web】一个非常简单的移动web消息框 【手记】解决EXCEL跑SQL遇“查询无法运行或数据库表无法打开...”