.Net Core Mvc 路由

在上一篇中,我们介绍了.net core mvc几个重要的服务,花一篇文章介绍也是有必要的,当我们配置好相应的MVC服务时,下一件事是将MVC中间件注册到应用程序的管道中,以便MVC框架可以处理请求并返回相应的内容(视图和JSON),而在使用MVC中间件时,是要使用到这些服务的。

在MVC框架中,每一个模块的重点放在各自特定的功能,为了使这些功能能正常工作,我们需要将HTTP请求发送到正确的控制器上,我们将这个过程称为路由。今天我们来看下MVC的中间件——路由。

在.Net Core Mvc入门那一篇,我们展示了Startup类完整配置Mvc的代码。我们再来看下代码:

using Microsoft.AspNetCore.Builder;using Microsoft.Extensions.DependencyInjection;
namespace FirstWebApp{ public class Startup { public void ConfigureServices(IServiceCollection services) { services.AddMvc(options=> { options.EnableEndpointRouting = false; }); }
public void Configure(IApplicationBuilder app) { app.UseMvcWithDefaultRoute(); } }}

代码非常简洁明了,没有其它配置。我们把目光放在Configure方法内部,这里使用了UseMvcWithDefaultRoute方法,这为我们提供了一个默认的路由规则是:{controller=Home}/{action=Index}/{id?}。当浏览器请求http://站点域名/或者http://站点域名/Home/Index时,它会匹配到HomeController类和Index方法获取响应。这也好理解,路由本来的目的是描述ASP.NET Core MVC用于处理HTTP请求并找到可以响应该请求的控制器的规则。.Net Core除了提供默认方式外,还提供了另外几种方式的配置。接下来我们一起看下他们的使用方法。

1、UseMvc

我们继续使用MVC入门的应用程序,将Configure方法内的UseMvcWithDefaultRoute方法改为UseMvc,这里UseMvc的作用是初始化一个新的RouteBuilder,并将处理程序的默认配置注册到MvcRouteHandler。而MvcRouteHandler构造函数中一些依赖项也会被初始化。此时,UseMvc并没有配置相应的路由规则。当我们启动项目会直接报404。为了顺利运行,我们在UseMvc方法传入Action<IRouteBuilder>参数,这也是UseMvc唯一的参数。我们来看下它的代码。

public void Configure(IApplicationBuilder app){ app.UseMvc(routes=>routes.MapRoute("Default", "{controller=Home}/{action=Index}/{id?}"));}

这个跟UseMvcWithDefaultRoute方法的路由规则是一样的。除了上面这种配置方式,我们还可以这样声明,代码如下 :

routes.MapRoute( name: "default_route", template: "{controller}/{action}/{id?}", defaults: new { controller = "Home", action = "Index" });

这两种都是比较常用。一旦配置了默认路由规则,我们还希望能通过基于特定需求添加自定义路由来扩展它。为此,我们可以使用MapRoute新增一条路由规则,如下代码:

public void Configure(IApplicationBuilder app){ app.UseMvc(routes =>    { routes.MapRoute( name: "About", template: "about", defaults: new { controller = "Home", action = "About" });
routes.MapRoute( name: "Default", template: "{controller=Home}/{action=Index}/{id?}"              );    });}

这样我们就额外添加了一条路由,该路由授予对Home控制器上的About操作的访问权/about。因为默认模式路由仍然存在,所以我们也可以使用常规/home/about路由访问“about”页面。

UseMvc作为一般的网站程序基本上能满足,如果要是想在进入路由规则后到控制器之间做操作,只能在UseMvc之前通过HttpContext自定义一些中间件来完成,但你要想获取路由值是行不通的。所以在3.0版本以上引入UseRouting和UseEndpoints结合使用。

2、UseEndpoints

UseEndPoints使用上必须在UseRouting方法之后,否则会报错。而UseEndPoints在模板配置上是没什么变化的,我们先来看下它的代码配置:

public void Configure(IApplicationBuilder app){ app.UseRouting();
app.UseEndpoints(endpoints => { endpoints.MapDefaultControllerRoute(); });}

这里路由使用一对中间件,由UseRouting和UseEndpoints注册:

  • UseRouting向中间件管道添加路由匹配。此中间件会查看应用中定义的终结点集,并根据请求选择最佳匹配。UseRouting中间件必须在其它中间件之前,如身份验证,授权或者使用路由值的自定义中间件。UseRouting中间件使用路由值和最终节点元数据替代当前的HttpContext,在3.0前的版本是没有这个功能。
  • UseEndpoints向中间件管道添加终结点执行。它会运行与所选终结点关联的委托。即执行匹配的节点映射到控制器上。

MapDefaultControllerRoute方法与UseMvcWithDefaultRoutes方法是一样的功能,当然我们也可以使用自定义模板来配置,具体代码如下:

app.UseEndpoints(endpoints =>{ endpoints.MapControllerRoute( name: "Default", pattern: "{controller}/{action}/{id?}", defaults: new { controller = "Home", action = "Index" } );});

如果有多个只要再新增一个endpoints就可以。

为什么在3.0引入Endpoint routing新概念?我们来对比下两张图:

图片

上面张图是使用UseMvc

图片

这张是使用UseRouting和UseEndpoints

从这两张图对比来看,节点路由使ASP.NET Core框架更加灵活,因为它使路由匹配和解析功能与节点分派功能脱钩,而该功能一直与MVC中间件捆绑在一起。在3.0以上版本更推荐使用UseRouting和UseEndpoints来配置。

关于路由的信息还有很多,比如:复杂模板配置、路由约束(正则表达式)、及通过属性来配置路由。而且官方文档(http://dwz.date/d4MJ)都有介绍,我们在学习的过程要结合官方文档。

本篇关于路由的介绍就到这,这里也没有深入的去剖析怎么解析路由,只是介绍一些简单的用法,但在项目中是够用。随着自己使用中的积累,结合github上的源代码慢慢去挖掘底层的逻辑也能剖析。

最后,祝学习愉快!

声明:文中观点不代表本站立场。本文传送门:http://eyangzhen.com/218352.html

联系我们
联系我们
分享本页
返回顶部