MASA MinimalAPI源码解析:为什么我们只写了一个app.MapGet,却生成了三个接口

yizhihongxing

源码解析:为什么我们只写了一个app.MapGet,却生成了三个接口

1.ServiceBase

1.AutoMapRoute

源码如下:

image-1683277238491

AutoMapRoute自动创建map路由,MinimalAPI会根据service中的方法,创建对应的api接口。

比如上文的一个方法:

public async Task<WeatherForecast[]> PostWeather() {
            return null;
        }

MinimalAPI会帮我们生成一个Post 的Weather接口,接口地址:

http://localhost:5187/api/v1/Users/Weather

2.ParseMethod

ParseMethod方法代码:

image-1683277247813

methodName 是方法名。PostWeather方法帮我们解析方法名中的关键信息生成对应请求类型。

3. ParseMethodPrefix

ParseMethodPrefix源码:

image-1683277257625

ParseMethodPrefix 用于判断自定义的方法前缀。

4.ServiceGlobalRouteOptions

ServiceGlobalRouteOptions源码:

image-1683277265824

ServiceGlobalRouteOptions配置方法前缀。

例如 方法前缀是Find,这个方法就会被解析成get请求。

注意:PostWeather 会生成 /api/v1/Users/Weather 。就是根据ServiceGlobalRouteOptions配置的。

5.关闭自动创建接口 AutoMapRoute

在构造函数中加入

RouteOptions.DisableAutoMapRoute = true;

禁用AutoMapRoute

image-1683277276893

禁用后swagger:

image-1683277284836

可以看到,禁用后,swagger就只有我们通过App.MapGet创建的接口了。

MASA minimalAPI 官方文档

原始用法:

var builder = WebApplication.CreateBuilder(args);
var app = builder.Build();
app.MapGet("/api/v1/Demo/HelloWorld", () => "Hello World");
app.Run();

用例:

Install-Package Masa.Contrib.Service.MinimalAPIs
  1. 添加MinimalAPI
var builder = WebApplication.CreateBuilder(args);
var app = builder.Services.AddServices(builder);
  1. 自定义Service并继承ServiceBase,如:
public class DemoService : ServiceBase
{
    public string HelloWorld()
    {
        return "Hello World";
    }
}

提示:继承ServiceBase的服务为单例模式注册,如果需要从DI获取获取

public async Task DeleteBasketByIdAsync(string id, [FromServices] IBasketRepository repository)
{
    await repository.DeleteBasketAsync(id);
}
阅读如遇样式问题,请前往个人博客浏览: https://note.raokun.top
拥抱ChatGPT,国内访问网站:https://ai.firstsaofan.top
开源项目地址:https://github.com/firstsaofan/TerraMours

原文链接:https://www.cnblogs.com/raok/archive/2023/05/05/17374885.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:MASA MinimalAPI源码解析:为什么我们只写了一个app.MapGet,却生成了三个接口 - Python技术站

(0)
上一篇 2023年5月5日
下一篇 2023年5月5日

相关文章

  • C#类的多态性详解

    C#类的多态性详解 什么是多态性? 在面向对象编程中,多态性是指同一种类型的对象,在不同的情况下可以呈现不同的行为。比如有一个父类A,有两个子类B和C,B和C都继承于A。当我们调用A中的某个方法时,B和C中的方法会根据自身的实现方式进行不同的行为表现。这种特性在代码的复用和扩展性方面非常有用。 C#中的多态性 C#支持两种类型的多态性:重载和覆盖。重载的多态…

    C# 2023年6月1日
    00
  • C# 使用Tcp/Udp协议的示例代码

    C#是一种面向对象的编程语言,它可以通过Tcp/Udp协议与其他网络设备进行通信。为了更好地掌握C#使用Tcp/Udp协议的示例代码,我们需要专门制定一套攻略,下面是具体的过程: 1.了解Tcp/Udp协议 在编写C#代码之前,需要先了解Tcp/Udp协议。Tcp协议是一种面向连接的协议,它提供可靠的数据传输和错误恢复机制,并保证数据的无序交付;Udp协议是…

    C# 2023年5月31日
    00
  • c#异步读取数据库与异步更新ui的代码实现

    你好,想要实现c#异步读取数据库并异步更新UI,可以采用以下步骤: 步骤一:建立异步的数据库连接 在c#中,可以使用SqlClient.SqlConnection类来建立数据库连接,并使用await关键字进行异步操作。具体代码如下: public async Task<SqlConnection> ConnectToDBAsync() { str…

    C# 2023年5月31日
    00
  • C#面向对象之模拟实现商城购物功能

    C#面向对象模拟实现商城购物功能可以分为以下几个步骤: 1. 创建商品类(Product)及其属性 第一步我们需要创建一个商品类,用来保存商品的相关信息。在C#中,创建类非常简单,只需要使用class关键字即可,具体实现如下: class Product { // 商品名称 public string Name { get; set; } // 商品价格 p…

    C# 2023年5月31日
    00
  • 使用C#9中records作为强类型ID的实例教程

    使用C#9中records作为强类型ID可以让程序变得更加健壮和安全,让我们来一步步学习如何使用它。 什么是records? records是C#9的新特性,它是值类型,用来表示不可变的数据对象,其简洁的语法使得代码更加易读、易写。 在records类型中,可以定义只读属性、可写属性和自动属性,但是不允许定义私有控制器,因为records类型是不可变的。 下…

    C# 2023年5月31日
    00
  • C# 注册表 操作实现代码

    C# 中操作注册表的方法非常简单,以下是一些基本的操作实现代码: 读取注册表 using Microsoft.Win32; // 打开要读取的注册表键 RegistryKey regKey = Registry.CurrentUser.OpenSubKey("SOFTWARE\\Microsoft\\Windows\\CurrentVersion\…

    C# 2023年6月6日
    00
  • 一文带你快速学会C#中WinForm框架的使用详解

    标题:一文带你快速学会C#中WinForm框架的使用详解 简介 在本文中,我将全面介绍C#中WinForm框架的使用,包括窗体的基本操作、控件的使用、事件的处理等内容。 窗体的基本操作 创建窗体 在C#中创建一个Windows窗体非常简单,只需要借助Visual Studio创建Windows Form应用即可。 窗体属性设置 在Windows窗体中,有很多…

    C# 2023年5月31日
    00
  • C#实现压缩HTML代码的方法

    让我来详细讲解一下C#实现压缩HTML代码的方法。下面是完整的攻略,包括Markdown格式文本、相关代码块和示例说明。 背景 在实际开发中,我们经常需要对HTML代码进行压缩,以减少文件的大小,提高页面的加载速度。C#提供了多种方法来实现HTML代码的压缩,本文将主要介绍HtmlAgilityPack库和Minifier库两种压缩HTML的方法。 Html…

    C# 2023年5月31日
    00
合作推广
合作推广
分享本页
返回顶部