zoukankan      html  css  js  c++  java
  • (转)Asp.Net MVC的路由机制

    原文地址: http://www.cnblogs.com/fly_dragon/archive/2010/10/08/1846009.html

         本篇文章是初识Asp.Net MVC2.0 的后续的介绍。此文将从Routing未开放源代码开始,还会对Asp.Net的Url重写技术做个简单介绍。并简单介绍Asp.Net MVC2.0 Url路由技术的使用。

         Url路由是MVC很重要的核心的一部分。不过它是单独于MVC项目,而且没有开源。新建一个MVC Web项目,打开Global.asax。我们看到系统帮我们添加了using System.Web.Routing 引用。Routing作为一个单独的dll被我们的项目引用。微软并没有对Routing进行开放源代码。所以:Asp.Net MVC是开源的,但是Routing不是开源的!

         首先讲一下Asp.Net的Url重写技术。一种最简单实现Url重写技术就是在Global.asax文件中

         protected void Application_BeginRequest(object sender, EventArgs e)
         {

             string originalUrl = Request.Url.PathAndQuery;//获取原先的Url请求(假的请求)

           //转化成真的url请求....

    HttpContext.Current.RewritePath(newurl);//将针对Url请求交给HttpContext

         }

         举个例子:一个假的Url地址:http://www.xxx.com/news/sports-2009-1-1-201.html

         看到上面的那个url其实很多情况下那不是一个真正的url,不一定存在sports-2009-1-1.html这么一个html页。我们如果在Application_BeginRequest事件中将这个url重写成这样:

    http://www.xxx.com/news/sports.aspx?date=2009-1-1&id=201 这才是真正的url!

         现在开始讲Asp.Net MVC的路由机制,首先要有个观念就是:Asp.Net MVC的url地址是表现的web程序的一个逻辑的结构。新建一个Asp.Net MVC Web项目。然后按F5直接可以运行。页面会自动跳转到http://localhost:端口号/Home/Index页面。玄机还是在Global.asax中。看下面代码:

    public static void RegisterRoutes(RouteCollection routes)
    {
    routes.IgnoreRoute(
    "{resource}.axd/{*pathInfo}");

    routes.MapRoute(
    "Default", // 路由名称
    "{controller}/{action}/{id}", // 带有参数的 URL
    new { controller = "Home", action = "Index", id = UrlParameter.Optional }, // 参数默认值
    new string[] { "MvcDemo.Controllers" }
    );
    Global.asax中的RegisterRoutes方法中注册了一个名字叫:Default的路由,格式是:
    http://localhost:端口号/controller/action
    并添加了这条路由的默认值new { controller
    = "Home", action = "Index"}。所以我们按F5启动的时候,
    地址栏是:
    http://localhost:端口号/
    这个样子,则匹配到我们的这条路由,并没有具体值,就匹配了我们的默认值。
    页面会则自动跳转到http://localhost:端口号/Home/Index页面

    先写到这,先回家吃饭!待续未完!
     

  • 相关阅读:
    03、CPU主频,和性能
    02、计算机组成原理相关知识
    常用正则表达式,手机号、固话号、身份证号等
    01、计算机原理结构,及冯诺依曼体系结构
    7-7 Complete Binary Search Tree (30分) 完全二叉搜索树
    7-2 Reversing Linked List (25分)
    7-1 Maximum Subsequence Sum (25分)
    6-17 Shortest Path [4] (25分)
    6-16 Shortest Path [3] (25分)
    6-15 Iterative Mergesort (25分)
  • 原文地址:https://www.cnblogs.com/fcsh820/p/1846524.html
Copyright © 2011-2022 走看看