【NetCore】10-路由定义

文章目录

  • [路由与终结点:如何规划好Web Api](#路由与终结点:如何规划好Web Api)
    • [1. 路由](#1. 路由)
      • [1.1 路由映射](#1.1 路由映射)
      • [1.2 路由注册方式](#1.2 路由注册方式)
      • [1.3 路由约束](#1.3 路由约束)
      • [总结: Web Api定义](#总结: Web Api定义)

路由与终结点:如何规划好Web Api

1. 路由

1.1 路由映射

路由系统核心作用是指URL和应用程序Controller的对应关系的一种映射
这种映射的作用:

1.把URL映射到对应的Controller的action上

2.根据Controller和action的名字生成URL

1.2 路由注册方式

  • 路由模板的方式 ⇒ 传统方式,可作为MVC页面的Web配置
  • RouteAttribute方式 ⇒ 更适合Web Api

1.3 路由约束

路由约束指的是路由如何匹配

  • 类型约束
  • 范围约束
  • 正则约束
  • 是否必选
  • 自定义IRouteConstraint

根据路由信息URL生成地址的类

  • LinkGenerator

  • IUrlHelper

    复制代码
      	/// <summary>
          /// 类型约束
          /// </summary>
          /// <param name="id">必须可以转long</param>
          /// <returns></returns>
          [HttpGet("{id:MyRouteConstraint}")]
          public bool OrderExist(object id)
          {
              return true;
          }
    
          /// <summary>
          /// 范围约束
          /// </summary>
          /// <param name="id"></param>
          /// <returns></returns>
          [HttpGet("{id:max(20)}")]
          public bool Max(long id)
          {
              return true;
          }
    
          /// <summary>
          /// 是否必选
          /// </summary>
          /// <param name="name"></param>
          /// <returns></returns>
          [HttpGet("{name:required}")]
          public bool Reque(string name)
          {
              return true;
          }
    
          /// <summary>
          /// 正则约束
          /// </summary>
          /// <param name="number"></param>
          /// <returns></returns>
          [HttpGet("{number:regex(^\\d{{3}}$)}")]
          public bool Bumber(string number)
          {
    
              return true;
          }

    // 自定义IRouteConstraint
    // 自定义路由约束类
    public class MyRouteConstraint : IRouteConstraint
    {
    public bool Match(HttpContext httpContext, IRouter route, string routeKey, RouteValueDictionary values, RouteDirection routeDirection)
    {
    if (RouteDirection.IncomingRequest == routeDirection)
    {
    var v= values[routeKey];
    if (long.TryParse(v.ToString(),out var value))
    {
    return true;
    }
    }
    return false;
    }
    }

    // startup中ConfigureServices
    services.AddRouting(options =>
    {
    options.ConstraintMap.Add("MyRouteConstraint", typeof(MyRouteConstraint));
    });

    [HttpGet("{id:MyRouteConstraint}")]
    public bool OrderExist([FromRoute]string id)
    {
    return true;
    }

LinkGenerator生成Url

复制代码
[HttpGet("{id:max(20)}")]
public bool Max([FromRoute] long id, [FromServices] LinkGenerator linkGenerator)
{
      var a = linkGenerator.GetPathByAction(HttpContext,
          action: "Reque",
          controller: "Order",
          values: new { name = "abc" });

      var uri = linkGenerator.GetUriByAction(HttpContext,
          action: "Reque",
          controller: "Order",
          values: new { name = "abc" });
      return true;

  }

总结: Web Api定义

  • Restful不是必须的
  • 约定好API的表达契约
  • 将API约束在特定目录下,如/api/
  • 使用ObsoleteAttribute标记即将废弃的API
相关推荐
2501_941236219 分钟前
C++与Node.js集成
开发语言·c++·算法
千里码aicood13 分钟前
springboot+vue考研复习交流平台设计(源码+文档+调试+基础修改+答疑)
vue.js·spring boot·后端
菠菠萝宝1 小时前
【Java手搓RAGFlow】-3- 用户认证与权限管理
java·开发语言·人工智能·llm·openai·qwen·rag
csdn_wuwt3 小时前
前后端中Dto是什么意思?
开发语言·网络·后端·安全·前端框架·开发
print(未来)3 小时前
C++ 与 C# 的性能比较:选择合适的语言进行高效开发
java·开发语言
四问四不知3 小时前
Rust语言入门
开发语言·rust
JosieBook3 小时前
【Rust】 基于Rust 从零构建一个本地 RSS 阅读器
开发语言·后端·rust
云边有个稻草人3 小时前
部分移动(Partial Move)的使用场景:Rust 所有权拆分的精细化实践
开发语言·算法·rust
一晌小贪欢4 小时前
Pandas操作Excel使用手册大全:从基础到精通
开发语言·python·自动化·excel·pandas·办公自动化·python办公
松涛和鸣5 小时前
11.C 语言学习:递归、宏定义、预处理、汉诺塔、Fibonacci 等
linux·c语言·开发语言·学习·算法·排序算法