0

0

C#的Minimal API是什么?如何快速创建轻量级的HTTP API?

煙雲

煙雲

发布时间:2025-11-11 19:39:03

|

323人浏览过

|

来源于php中文网

原创

Minimal API 是一种在 .NET 6 中引入的轻量级 HTTP 服务构建方式,1. 它通过简化路由和处理逻辑定义,无需控制器即可快速搭建 API;2. 核心优势包括减少样板代码、提升开发效率、降低学习成本、资源占用少且易于容器化;3. 支持与 ASP.NET Core 生态无缝集成,如依赖注入、中间件、日志和数据库;4. 可通过 dotnet new web 快速创建项目,并在 Program.cs 中使用 lambda 表达式定义 GET、POST 等路由;5. 内置 JSON 序列化支持,可轻松返回或接收对象数据;6. 能注册服务(如 DbContext、Singleton 服务)并在请求中直接注入使用;7. 适合微服务、原型开发等场景,虽简洁但仍可扩展验证、错误处理等机制。

c#的minimal api是什么?如何快速创建轻量级的http api?

Minimal API 是 C# 中一种简洁高效的方式来创建轻量级的 HTTP 服务,它从 .NET 6 开始成为默认项目模板的一部分。它的核心特点是用最少的代码定义路由和处理逻辑,无需控制器(Controller),特别适合构建小型服务、微服务或快速原型。

Minimal API 的核心优势

它去除了传统 ASP.NET Core MVC 中的冗余结构,比如控制器类、动作方法等,直接在 Program.cs 中通过简单的 lambda 表达式定义接口行为。这种方式减少了样板代码,提高了开发效率。

  • 代码更少,启动更快
  • 学习成本低,适合新手入门
  • 资源占用小,适合容器化部署
  • 与 ASP.NET Core 生态无缝集成(如依赖注入、中间件)

快速创建一个 Minimal API 项目

使用 .NET CLI 可以几秒内生成并运行一个基础 API。

  1. 打开终端,运行命令创建新项目:
    dotnet new web -n MyApi
  2. 进入项目目录:
    cd MyApi
  3. 运行项目:
    dotnet run

此时会看到服务监听在 5000 和 5001 端口(HTTP/HTTPS),浏览器访问 https://www.php.cn/link/6060d322713797e84f598ea25c812cab 就能看到 "Hello World!"。

添加实际的 API 路由示例

修改 Program.cs 文件,添加几个常见类型的接口:

var builder = WebApplication.CreateBuilder(args);
var app = builder.Build();

// 基础 GET 请求
app.MapGet("/hello", () => "Hello, Minimal API!");

// 带路径参数
app.MapGet("/user/{id}", (int id) => $"User ID: {id}");

// 返回 JSON 数据
app.MapGet("/api/users", () => new[] {
  new { Id = 1, Name = "Alice" },
  new { Id = 2, Name = "Bob" }
});

// POST 接收 JSON 输入
app.MapPost("/api/users", (User user) => Results.Created($"/api/users/{user.Id}", user));

app.Run();

RoomGPT
RoomGPT

使用AI为每个人创造梦想的房间

下载

record User(int Id, string Name);

这个例子展示了如何处理不同类型的请求,并自动序列化/反序列化 JSON 数据,得益于内置的 System.Text.Json 支持。

集成日志、数据库和其他服务

尽管轻量,Minimal API 仍可轻松接入完整功能。例如注册服务:

builder.Services.AddSingleton();
builder.Services.AddDbContext(options =>
  options.UseSqlite("Data Source=app.db"));

然后在路由中通过参数获取服务实例:

app.MapGet("/data", (IDataService service) => service.GetData());

基本上就这些。Minimal API 让你用最直接的方式暴露 HTTP 接口,不复杂但容易忽略细节,比如模型验证、错误处理等,可在需要时逐步增强。

相关专题

更多
什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

175

2024.05.11

Golang 中间件开发与微服务架构
Golang 中间件开发与微服务架构

本专题系统讲解 Golang 在微服务架构中的中间件开发,包括日志处理、限流与熔断、认证与授权、服务监控、API 网关设计等常见中间件功能的实现。通过实战项目,帮助开发者理解如何使用 Go 编写高效、可扩展的中间件组件,并在微服务环境中进行灵活部署与管理。

147

2025.12.18

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

400

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

528

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

306

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

69

2025.09.10

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

311

2023.08.02

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

311

2023.08.02

虚拟号码教程汇总
虚拟号码教程汇总

本专题整合了虚拟号码接收验证码相关教程,阅读下面的文章了解更多详细操作。

25

2025.12.25

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 5.4万人学习

C 教程
C 教程

共75课时 | 3.7万人学习

C++教程
C++教程

共115课时 | 10.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号