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 服务:
1. 创建项目
在命令行运行:
dotnet new web -n MyMinimalApicd MyMinimalApi
2. 查看生成的 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 接口,不复杂但容易忽略细节。只要理解其“函数即路由”的思路,就能高效开发轻量服务。
以上就是.NET中的Minimal API是什么?如何用它快速构建轻量级Web服务?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1441662.html
微信扫一扫
支付宝扫一扫