请求一个MVC页面的处理过程

1.浏览器发送一个Home/Index 的链接请求到iis。iis发现时一个asp.net处理程序。则调用asp.net_isapi 扩展程序发送asp.net框架

2.在asp.net的第七个管道事件中会遍历UrlRoutingModule中RouteCollection的RoteBase集合 通过调用其GetRouteData方法进行路由匹配返回一个实现了IRoteHandler的类的对象,没有则返回null继续向下遍历

3.调用IRoteHandler的getIhttpHanderl获得实现了IhttpHandler的类的对象。再在11 到12个事件管道调用其ProcessRequset 执行处理逻辑将结果写入response

这里我们会发现很多个扩展点 1.自定义RoteBase 写入集合  2.自定义IroteHandler   3.自定义IhttpHandler

尝试自定一个RoteBase 并添加到UrlRoutingModule的RoteBase集合中

    public class MyRote : RouteBase
    {
        /// <summary>
        /// 此方法是处理请求是否跟当前路由匹配
        /// </summary>
        /// <param name="httpContext"></param>
        /// <returns></returns>
        public override RouteData GetRouteData(HttpContextBase httpContext)
        {
            //假如我们定义 如果是谷歌用户则命中路由当前路由
            )
            {
                RouteData rd= new RouteData(this, new MvcRouteHandler());
                //假设命中了此路由 解析获得请求控制器为Home action方法为Index
                rd.Values.Add("controller", "Home");
                rd.Values.Add("action", "MyRoteIndex");
                return rd;
            }
            return null;
        }

        /// <summary>
        /// 此方法 在通过Url.action()的时候根据当前路由生成路径
        /// </summary>
        /// <param name="requestContext"></param>
        /// <param name="values"></param>
        /// <returns></returns>
        public override VirtualPathData GetVirtualPath(RequestContext requestContext, RouteValueDictionary values)
        {
            return new VirtualPathData(this,"Home/MyRoteIndex");
        }
    }在RouteConfig添加到UrlRoutingModule 的RouteCollection中
public class RouteConfig
    {
        public static void RegisterRoutes(RouteCollection routes)
        {
            routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
            /***
             *  因为路由匹配是遍历匹配的 所以我们写到第一个位置。否则可能会出现匹配到下面的路由
             *添加到RoteBase集合。下面的方法是个扩展方法内部也是调用的add方法
             ***/
            routes.Add("myRote", new MyRote.MyRote());
            routes.MapRoute(
                name: "Default",
                url: "{controller}/{action}/{id}",
                defaults: new { controller = "Home", action = "Index", id = UrlParameter.Optional }
            );

        }
    }这个时候我们用谷歌就会发现无论我们请求哪个页面 都是调用Home/MyRoteIndex  还有在视图页面通过@url.acton 通过路由生成链接也是都是Home/MyRoteIndex

2.自己实现自己的RoteHandler 和IhttpHandler
    public class MyRoteHandler :IRouteHandler
    {
        public IHttpHandler GetHttpHandler(RequestContext requestContext)
        {
            //返回我们自己的IttpHandler处理对象
            return new MyIHttpHandler();
        }
    }

    public class MyIHttpHandler : IHttpHandler
    {

        public bool IsReusable
        {
            get { return true; }
        }

        /***
         * 我们之前说了 在第11到12个事件管道是调用这个方法写入response
         * MVC实现的IhttpHandler则是通过匹配的路由 反射调用指定控制器的action方法 再调用ActionrResult的ExcuteReuslt方法将结果写入response
         * asp.net处理页面则是调用后台页类的ProcessRequset方法处理我们程序员写的逻辑了
         ***/
        public void ProcessRequest(HttpContext context)
        {
            )
            {
                context.Response.Write("当前是谷歌浏览器");
            }
            )
            {
                context.Response.Write("当前是Ie浏览器");
            }
            else
            {
                context.Response.Write("其他浏览器");
            }
        }
    }
        /// <summary>
        /// 此方法是处理请求是否跟当前路由匹配
        /// </summary>
        /// <param name="httpContext"></param>
        /// <returns></returns>
        public override RouteData GetRouteData(HttpContextBase httpContext)
        {
            //方便调试则默认他是全部请求匹配此路由
            if (true)
            {
                //这里的RoteHandler则返回我们自己的实现
                RouteData rd= new RouteData(this, new MyRoteHandler());
                //假设命中了此路由 解析获得请求控制器为Home action方法为Index
                rd.Values.Add("controller", "Home");
                rd.Values.Add("action", "MyRoteIndex");
                return rd;
            }
        }

        /// <summary>
        /// 此方法 在通过Url.action()的时候根据当前路由生成路径
        /// </summary>
        /// <param name="requestContext"></param>
        /// <param name="values"></param>
        /// <returns></returns>
        public override VirtualPathData GetVirtualPath(RequestContext requestContext, RouteValueDictionary values)
        {
            return new VirtualPathData(this,"Home/MyRoteIndex");
        }

因为都是匹配我们的自己实现的路由 和返回我们自己的RoteHandelr 最终结果是请求任何url都是执行我们自己的IttpHanler的处理逻辑的方法



 

最新文章

  1. SQL Server-5种常见的约束
  2. iTestSharp的简单应用
  3. 【JavaScript兼容】关于IE8及以下无法通过getElementsByClassName()方法获得元素的解决方法
  4. hadoop 多表join:Map side join及Reduce side join范例
  5. app进入后台之后接收到通知,点进去进入新的页面,再次进入后台,再点击通知进入页面(,两次通过通知进入的页面,创建了两次,会多一个页面,)解决办法监听
  6. 智能车学习(十一)&mdash;&mdash;陀螺仪学习
  7. Objective-C语言多态性
  8. 华为 HG8245C 光猫 修改无线用户数限制+hw_ctree.xml 文件解密
  9. dedecms 调用channel子栏目的id问题
  10. 简单的说说jsonp
  11. poj 3740 Easy Finding 二进制压缩枚举dfs 与 DLX模板详细解析
  12. 关于网页显示乱码问题的一些个人见解(PHP、JSP...)
  13. LINUX RHEL6.5字符界面安装图形化桌面
  14. 201521123040《Java程序设计》第14周学习总结
  15. Scrapy框架--使用cookie
  16. python optparser模块
  17. Web界面实现数据库增删改查过程
  18. BZOJ4543[POI2014]Hotel加强版——长链剖分+树形DP
  19. lsass.exe占用cpu 解决方法
  20. Luogu P1546 最短网络 Agri-Net

热门文章

  1. 03Spring_bean的创建和作用域以及生命周期
  2. 让Bootstrap轮播插件carousel支持左右滑动手势的三种方法
  3. ISAPI_Rewrite中文手册
  4. 简单的js验证码
  5. PRML读书会第七章 Sparse Kernel Machines(支持向量机, support vector machine ,KKT条件,RVM)
  6. Ace - Responsive Admin Template
  7. 基于DDD的.NET开发框架 - ABP模块设计
  8. flash
  9. 转 为什么文件存储要选用B+树这样的数据结构?
  10. 网络流 HDU 3605