Minimal API从.NET 6引入,通过极简语法在Program.cs中直接定义路由,无需控制器,支持依赖注入、Swagger、模型验证,适用于微服务与原型开发。

.NET中的Minimal API 是从 .NET 6 开始引入的一种简化方式,用于快速构建轻量级、高性能的Web服务。它去除了传统 ASP.NET Core MVC 中的一些复杂结构(如控制器类、路由属性等),让你用极少的代码就能启动一个HTTP服务,特别适合构建小型API、微服务或原型项目。
Minimal API 的核心特点
• 极简语法:不需要定义控制器(Controller),直接在 Program.cs 中通过委托处理请求。• 高性能:减少了中间抽象层,启动快,内存占用低。
• 依赖少:只加载必要的中间件和服务,适合容器化部署。
• 与 ASP.NET Core 完全兼容:仍可使用 DI、日志、认证等高级功能。
如何创建一个 Minimal API
以下是一个最简单的例子,展示如何用 Minimal API 快速搭建一个返回 JSON 的 Web 服务:
在命令行运行:
dotnet new web -n MyMinimalApi cd MyMinimalApi2. 查看生成的 Program.cs
默认代码已经是最简结构:
var builder = WebApplication.CreateBuilder(args);
var app = builder.Build();
app.MapGet("/", () => "Hello World!");
app.Run();
3. 添加更多路由和数据响应你可以添加 GET、POST 等方法,并返回对象自动序列化为 JSON:
app.MapGet("/weather", () =>
{
var forecasts = new[]
{
new { Date = DateTime.Now, TemperatureC = 25, Summary = "Sunny" }
};
return Results.Ok(forecasts);
});
app.MapPost("/users", (User user) =>
{
// 模拟保存用户
return Results.Created($"/users/{user.Id}", user);
});
集成常用功能
• 启用 Swagger / OpenAPI安装 Swashbuckle.AspNetCore:
dotnet add package Swashbuckle.AspNetCore然后在 Program.cs 中添加:
builder.Services.AddEndpointsApiExplorer();
builder.Services.AddSwaggerGen();
// ... Build 之后
if (app.Environment.IsDevelopment())
{
app.UseSwagger();
app.UseSwaggerUI();
}
访问 /swagger 即可查看API文档。
• 依赖注入(DI)注册服务并注入到处理函数中:
builder.Services.AddSingleton• 模型绑定与验证(); app.MapGet("/data", (IDataService service) => Results.Ok(service.GetData()));
Minimal API 支持自动绑定 JSON 请求体到 POCO 类型,并可通过
Validate 方法做验证:
app.MapPost("/books", (Book book) =>
{
if (string.IsNullOrEmpty(book.Title))
return Results.BadRequest("Title is required");
return Results.Created($"/books/{book.Id}", book);
});
适用场景与建议
• 适合:快速原型、内部工具、微服务、无服务器函数(如 Azure Functions 风格)。• 不适合:大型应用中需要复用逻辑、复杂权限控制或多层架构时,还是推荐使用 MVC 控制器。
• 最佳实践:将路由分组、使用单独文件组织端点、合理使用中间件。 基本上就这些。Minimal API 让你几行代码就能跑起一个 Web 接口,不复杂但容易忽略细节。只要理解其“函数即路由”的思路,就能高效开发轻量服务。










