zoukankan      html  css  js  c++  java
  • ASP.NET MVC自定义Module记录管道事件执行顺序

    1. 在Visual Studio 新建项目,模板为空,下面结构选择MVC。

    2. 在项目中新建一个类MyModule,实现IHttpModule接口

    namespace SimpleApp.Infrastructure
    {
        /// <summary>
        /// 记录请求管道事件执行顺序
        /// </summary>
        public class MyModule : IHttpModule
        {
            public void Dispose()
            {
            }
    
            public void Init(HttpApplication context)
            {
                //下面是记录事件的执行
                //提供自定义日志记录实现的示例
                context.BeginRequest += (src, args) => RecordEvent(context);
    
                context.AuthenticateRequest += (src, args) => RecordEvent(context);
                context.PostAuthenticateRequest += (src, args) => RecordEvent(context);
    
                context.AuthorizeRequest += (src, args) => RecordEvent(context);
                context.PostAuthorizeRequest += (src, args) => RecordEvent(context);
    
                context.ResolveRequestCache += (src, args) => RecordEvent(context);
                context.PostResolveRequestCache += (src, args) => RecordEvent(context);
    
                //MapRequestHandler:仅支持IIS7以上,Net Framwork3.0以上的集成模式
                context.MapRequestHandler += (src, args) => RecordEvent(context);
                context.PostMapRequestHandler += (src, args) => RecordEvent(context);
    
                context.AcquireRequestState += (src, args) => RecordEvent(context);
                context.PostAcquireRequestState += (src, args) => RecordEvent(context);
    
    
                context.PreRequestHandlerExecute += (src, args) => RecordEvent(context);
                context.PostRequestHandlerExecute += (src, args) => RecordEvent(context);
    
                context.ReleaseRequestState += (src, args) => RecordEvent(context);
                context.PostReleaseRequestState += (src, args) => RecordEvent(context);
    
                context.UpdateRequestCache += (src, args) => RecordEvent(context);
                context.PostUpdateRequestCache += (src, args) => RecordEvent(context);
    
                //LogRequest、PostLogRequest支持IIS7以上,Net Framwork3.0以上的集成模式
                context.LogRequest += (src, args) => RecordEvent(context);
                context.PostLogRequest += (src, args) => RecordEvent(context);
    
                context.EndRequest += (src, args) => RecordEvent(context);
    
                context.PreSendRequestHeaders += (src, args) => RecordEvent(context);
                context.PreSendRequestContent += (src, args) => RecordEvent(context);
    
                context.Error += (src, args) => RecordEvent(context);
                context.RequestCompleted += (src, args) => RecordEvent(context);
    
                context.Disposed += (src, args) => RecordEvent(context);
            }
    
            private static int index = 0;
            private void RecordEvent(HttpApplication context)
            {
                index++;
                string eventName = HttpContext.Current.CurrentNotification.ToString();
                if (eventName== "BeginRequest")
                {
                    index = 1;
                }
                if (HttpContext.Current.IsPostNotification)
                {
                    eventName = "Post" + eventName;
                }
                using (StreamWriter sw = new StreamWriter(@"d:asplog.txt",true,Encoding.UTF8))
                {
                    sw.WriteLine("=====================================");
                    sw.WriteLine(index+": "+eventName);
                    sw.WriteLine("=====================================");
                    sw.Flush();
                }
            }
        }
    
    
    }

    3. 在App_Start文件夹中,定义类ModuleRegistration,注册MyModule

    using System.Web;
    
    [assembly: PreApplicationStartMethod(typeof(SimpleApp.ModuleRegistration), "RegisterModule")]
    namespace SimpleApp
    {
        public class ModuleRegistration
        {
            public static void RegisterModule()
            {
                HttpApplication.RegisterModule(typeof(SimpleApp.Infrastructure.MyModule));
            }
        }
    }

    4. 新建HomeController,并新建Index视图

    5. ctrl+F5运行项目,然后关闭,在d盘可以看懂asplog.txt记录的请求管道中事件的执行顺序

  • 相关阅读:
    iOS技术框架构和更新版本的技术特性
    iOS第三方常用类库
    查看MySQL系统变量的命令
    解决WIN7下VMWARE虚拟机无法上网问题
    MySQL性能优化的最佳20+条经验
    PHP高效率写法(详解原因)
    google官方建议使用的网站性能测试工具
    ETL工具-KETTLE教程 实例实战4----转换(值映射、列转行,增加常量、增加序列等)
    ETL工具-KETTLE教程实例实战2----环境介绍
    ETL工具-KETTLE教程实例实战1----术语和定义
  • 原文地址:https://www.cnblogs.com/AlexanderZhao/p/10588001.html
Copyright © 2011-2022 走看看