`

如何在ASP.NET站点中实现对用户请求的监控

 
阅读更多

如何在ASP.NET站点中实现对用户请求的监控

有朋友问到这个问题:一个站点中,如果希望监控到用户请求的地址,不管是他通过在地址栏输入地址,还是通过点击链接来请求的。要做这样的事情,其实重点是要理解APS.NETHttpModule的机制。我们可以编写一个自定义的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方法中为applicationBeginRequest事件绑定一个事件处理程序。

 

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引擎来处理的。那么怎么样改变这个行为呢?我们可以修改站点的配置:

点击“配置”

点击“添加”

 

分享到:
评论

相关推荐

    IIS网站流量监控软件

     方便服务器管理员在服务器中查询出有问题的站点,或者比较浪费服务器资源的站点。配合《智创IIS网站专业级防火墙系统》可以实时观看IIS中每个ASP/PHP/.NET脚本的执行时间和执行情况,可以非常方便的用于解决IIS...

    IIS网站流量监控软件(绿色版)

    方便服务器管理员在服务器中查询出有问题的站点,或者比较浪费服务器资源的站点。配合《智创IIS网站专业级防火墙系统》可以实时观看IIS中每个ASP/PHP/.NET脚本的执行时间和执行情况,可以非常方便的用于解决IIS经常...

    智创IIS网站流量监控软件免费版

     方便服务器管理员在服务器中查询出有问题的站点,或者比较浪费服务器资源的站点。配合《智创IIS网站专业级防火墙系统》可以实时观看IIS中每个ASP/PHP/.NET脚本的执行时间和执行情况,可以非常方便的用于解决IIS...

    IIS 网站流量分析软件

     方便服务器管理员在服务器中查询出有问题的站点,或者比较浪费服务器资源的站点。配合《智创IIS网站专业级防火墙系统》可以实时观看IIS中每个ASP/PHP/.NET脚本的执行时间和执行情况,可以非常方便的用于解决IIS...

    wiki-down:基于 Markdown 的 .NET mongodb wiki

    ASP.NET 内容服务器 MVC 网页演示 网站和文章导航 只读系统监视器 网络API 阅读/撰写文章 读取系统数据 MongoDB 数据库 文章 - 历史、草稿、垃圾 系统 - 日志、审计、配置 WPF 系统管理工具 管理系统配置 监控系统...

    vc++ 开发实例源码包

    主要的实现在CListReport类中。 CListCtrlTest 演示了重载CListCtrl后的使用方法。 CListItem Drawing 演示了其它控件(全部)阙套到List中并自绘等,学习自绘以及阙套CListCtrl 控件的好实例。 ColorStatic 自绘...

    JAVA上百实例源码以及开源项目

     当用户发送第一次请求的时候,验证用户登录,创建一个该qq号和服务器端保持通讯连接得线程,启动该通讯线程,通讯完毕,关闭Scoket。  QQ客户端登录界面,中部有三个JPanel,有一个叫选项卡窗口管理。还可以更新...

    JAVA上百实例源码以及开源项目源代码

     当用户发送第一次请求的时候,验证用户登录,创建一个该qq号和服务器端保持通讯连接得线程,启动该通讯线程,通讯完毕,关闭Scoket。  QQ客户端登录界面,中部有三个JPanel,有一个叫选项卡窗口管理。还可以更新...

Global site tag (gtag.js) - Google Analytics