Minimal API从.NET 6引入,通过极简语法在Program.cs中直接定义路由,无需控制器,支持依赖注入、Swagger、模型验证,适用于微服务与原型开发。
.NET中的Minimal API 是从 .NET 6 开始引入的一种简化方式,用于快速构建轻量级、高性能的Web服务。它去除了传统 ASP.NET Core MVC 中的一些复杂结构(如控制器类、路由属性等),让你用极少的代码就能启动一个HTTP服务,特别适合构建小型API、微服务或原型项目。
以下是一个最简单的例子,展示如何用 Minimal API 快速搭建一个返回 JSON 的 Web 服务:
1. 创建项目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. 添加更多路由和数据响应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);
});
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()));
Validate 方法做验证:
app.MapPost("/books", (Book book) =>
{
if (string.IsNullOrEmpty(book.Title))
return Results.BadRequest("Title is required");
return Results.Created($"/books/{book.Id}", book);
});