ASP.NET Core 3.x - 为什么采用新的 Endpoint Routing 路由系统
Endpoint Routing 路由系统
ASP.NET Core 3.x 使用了一套叫做 Endpoint Routing 的路由系统。这套路由系统在ASP.NET Core 2.2 的时候就开始露面了。
这套Endpoint Routing路由系统提供了更强大的功能和灵活性,以便能更好的处理请求。
早期ASP.NET Core的路由系统
我们先回顾一下早期版本的ASP.NET Core的路由系统:
在早期的ASP.NET Core框架里,HTTP请求进入中间件管道,在管道的结尾处,有一个Router中间件,也就是路由中间件。这个路由中间件会把HTTP请求和路由数据发送给MVC的一个组件,它叫做MVC Router Handler。
这个MVC 路由 Handler就会使用这些路由数据来决定哪个Controller的Action方法应该来负责处理这个请求。
然后 Router中间件就会执行被选中的Action方法,并生成响应,而这个响应就会顺着中间件的管道原路返回。
问题出在哪?
为什么早期的这套路由系统被抛弃了?它有什么问题?
第一个问题就是,在被MVC处理之前,其它的中间件不知道最后哪个Action方法会被选中来处理这个请求。这对像Authorization(授权),Cors这样的中间件会造成很大的困扰,因为他们不能提前知道该请求会被送往哪里。
第二个问题就是,这套流程会把MVC和路由的职责紧密的耦合在一起,而实际MVC的本职工作应该仅仅就是生成响应。
Endpoint Routing 路由系统前来营救
Endpoint routing 路由系统,它把MVC的路由功能抽象剥离出来,并放置到中间件管道里,从而解决了早期ASP.NET Core路由系统的那两个问题。
而在Endpoint Routing 路由系统里,其实一共有两个中间件,它们的名称有点容易混淆,但是你只要记住他们的职责即可:
Endpoint Routing 中间件。它决定了在程序中注册的哪个Endpoint应该用来处理请求。
Endpoint 中间件。它是用来执行选中的Endpoint,从而让其生成响应的。
所以,Endpoint Routing的流程图大致如下:
在这里,Endpoint Routing 中间件会分析进来的请求,并把它和在程序中注册的Endpoints进行比较。它会使用这些 Endpoints 上面的元数据来决定哪个是处理该请求的最佳人选。然后,这个选中的Endpoint 就会被赋给请求的对象,而其它后续的中间件就可以根据这个选中的Endpoint,来做一些自己的决策。在所有的中间件都执行完之后,这个被选中的Endpoint最终将被 Endpoint中间件所执行,而与之关联的Action方法就会被执行。
ASP.NET Core 3.x - 为什么采用新的 Endpoint Routing 路由系统相关推荐
- ASP.NET Core 源码阅读笔记(5) ---Microsoft.AspNetCore.Routing路由
这篇随笔讲讲路由功能,主要内容在项目Microsoft.AspNetCore.Routing中,可以在GitHub上找到,Routing项目地址. 路由功能是大家都很熟悉的功能,使用起来也十分简单,从 ...
- ASP.NET Core 系列视频完结,新项目实战课程发布。
今天把MVC的章节完成了,给大家从头到尾做了一个登录注册的示例,带前后端Model验证,算是完整的示例.同时借助于eShopOnContainers的示例也做了一个DBContextSeed的包装器来 ...
- ASP.NET Core 3.x - Endpoint Routing 路由体系的内部机制
Endpoint是什么? Endpoint简单的可以理解为这样的一些类,它们包含一个请求的委托(Request Delegate)和其它的一些元数据,使用这些东西,Endpoint类可以生成一个响应. ...
- ASP.NET Core应用的7种依赖注入方式
ASP.NET Core框架中的很多核心对象都是通过依赖注入方式提供的,如用来对应用进行初始化的Startup对象.中间件对象,以及ASP.NET Core MVC应用中的Controller对象和V ...
- ASP.NET Core 3.0中使用动态控制器路由
原文:Dynamic controller routing in ASP.NET Core 3.0 作者:Filip W 译文:https://www.cnblogs.com/lwqlun/p/114 ...
- ASP.NET Core 2 学习笔记(四)依赖注入
原文:ASP.NET Core 2 学习笔记(四)依赖注入 ASP.NET Core使用了大量的依赖注入(Dependency Injection, DI),把控制反转(Inversion Of Co ...
- [转载]ASP.NET Core文件上传与下载(多种上传方式)
ASP.NET Core文件上传与下载(多种上传方式) 前言 前段时间项目上线,实在太忙,最近终于开始可以研究研究ASP.NET Core了. 打算写个系列,但是还没想好目录,今天先来一篇,后面在整理 ...
- 在 ASP.NET Core Web API中使用 Polly 构建弹性容错的微服务
在 ASP.NET Core Web API中使用 Polly 构建弹性容错的微服务 https://procodeguide.com/programming/polly-in-aspnet-core ...
- ASP.NET Core依赖注入初识与思考
一.前言 在上一篇中,我们讲述了什么是控制反转(IoC)以及通过哪些方式实现的.这其中,我们明白了,「控制反转(IoC)」 是一种软件设计的模式,指导我们设计出更优良,更具有松耦合的程序,而具体的实现 ...
最新文章
- “ Error:(1, 1) java: 非法字符: ‘\ufeff‘ ”错误的解决方法
- struts2被淘汰的原因
- ExtJs中ComboBox使用之技巧
- python文件命名 数字_在python中,如何导入文件名以数字开头
- Build Path
- 数字图像处理:名词解释
- svnadmin命令[转]
- 【数电】数电基础知识
- 微信小程序服务器向客户端发送通知消息,微信小程序消息推送
- ERROR: Cannot uninstall ‘PyYAML‘. It is a distutils installed project and thus we cannot...
- easyPOI导出时间字段注意事项
- layui镜像站 lh_yun.gitee.io/layui
- 七夕礼物送什么给男朋友好?七夕礼物清单
- 算法题_遍历三角矩阵
- 功率单位mW和dBm的换算
- win11系统下word文档中鼠标指针消失解决方案
- 丰田生产方式和水库模型的类比分析
- 怎样建设自组织的团队
- 虚假招聘的岗位的特征有哪些呢
- 1.Echarts饼状图详解及示例