路由介绍
-
路由是用来把请求映射到路由处理程序。应用程序一启动就配置了路由,并且可以从URL中提取值用于处理请求。它还负责使用 ASP.NET 应用程序中定义的路由来生成链接。
-
路由的作用:定义用户请求与控制器方法之间的映射关系。
-
ASP.NET Core中包含两种形式的路由,即基于约定的路由和特性路由。
-
基于约定的路由:通常在Startup类的Configure方法中,我们可以创建这一类的路由,这一类的路由通过指定路由约定或路由模块来决定程序对URL的路由方式,这种方式定义的路由对整个应用程序都有效
-
特性路由(用这个多):则是以C#的特性方式,将MVC中定义的路由特性应用到Controller以及Action来为其添加路由,这一种方式仅对特性所应用的Controller或Action有效。特性路由能够为具体的某个Controller或Action设置路由,方法是使用[Route]特性。
- 特性路由更为常见的使用方式是通过HTTP动词特性来创建,如[HttpGet]、[HttpPost]、[HttpPut]、[HttpPatch]、[HttpDelete]、[HttpHead]。将这些特性应用在一个Action上,不仅能够设置当前Action所支持的HTTP方法,并且也能够为其指定路由以及方法参数。
-
路由规则配置
即如何配置路由:一个用户请求(实际请求地址)过来之后 - 通过一个路由规则去找到对应的(匹配)- 匹配之后,会产生相关的路由数据 - 依据这些路由数据去找对应的控制器方法。原理过程如下图所示:(所以一般在路由里一般包含这些数据:controller、action)
路由配置
-
IRouteBuilder:通过MapRoute方法配置路由模板(有点老模板需要自己写,现在.NET5.0 暂时不用这个,因为现在都被封装在app.UseEndpoints(endpoints => { endpoints.MapControllers(); }); 里面了)
-
RouteAttribute
-
应用在控制器及方法上
-
通过Template属性配置路由模板
-
路由的使用
见代码。中括号中可以写controller或者action,但是controller用的更多,先学会这个样子用就行了。
namespace WebApplication2.Controllers
{
[ApiController]
[Route("[controller]")] //[Route("admin/patient")]
// 在PatientController这个类上直接写route特性
// 跟的参数里面写当前控制器访问的话,它对应的模板是什么admin/controller
// 在这里,[Route("[controller]")]和[Route("admin/patient")]都可以
// 但是前者是动态的(自动解析,自动判断PatientController前面试Patient),后者是写死了不能变
public class PatientController : ControllerBase
{
private readonly PatientDbContext _patientDbContext;
public PatientController(PatientDbContext patientDbContext)
{
_patientDbContext = patientDbContext;
}
······
}
}
##路由约束
1. 对路由数据进行约束(比如约定id必须为int)
2. 只有满足约束条件才能匹配成功
##路由数据
+ 路由数据也是请求数据的一部分
+ 路由数据与表单数据一样,也可以绑定到参数上
+ 默认是通过名称进行匹配,也可以通过FromRouteAttribute配置参数与路由数据的映射关
系
##路由数据绑定
##参考视频
<https://www.bilibili.com/video/BV1dK4y1b7XE?from=search&seid=15164078199988327095>
时间多也可以看一下这个:<https://www.bilibili.com/video/BV1y7411A7TJ?p=1>
文档可以看一下:<https://blog.csdn.net/smumuy/article/details/109426028?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522161430765116780265420108%2522%252C%2522scm%2522%253A%252220140713.130102334.pc%255Fall.%2522%257D&request_id=161430765116780265420108&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~all~first_rank_v2~rank_v29-1-109426028.pc_search_result_hbase_insert&utm_term=.NET%E4%B8%AD%E5%A6%82%E4%BD%95%E4%BD%BF%E7%94%A8%E8%B7%AF%E7%94%B1>