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 MyMinimalApi
var builder = WebApplication.CreateBuilder(args);
var app = builder.Build();
app.MapGet("/", () => "Hello World!");
app.Run();
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
builder.Services.AddEndpointsApiExplorer();
builder.Services.AddSwaggerGen();
// ... Build 之后
if (app.Environment.IsDevelopment())
{
app.UseSwagger();
app.UseSwaggerUI();
}
/swagger 即可查看API文档。
• 依赖注入(DI)builder.Services.AddSingleton<IDataService, DataService>();
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);
});
以上就是.NET中的Minimal API是什么?如何用它快速构建轻量级Web服务?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号