当前位置: 首页 > news >正文

.NET 10 使用 Microsoft.AspNetCore.OpenApi 实现 API 版本管理

为什么 API 版本管理如此重要?

API 版本管理的核心目标是:在不破坏现有用户的前提下,持续迭代和改进 API。通过版本管理,我们可以:

  • 引入新功能:在新版本中添加字段、接口等,而不影响旧版本的用户。
  • 修复 bug:在新版本中修复问题,而不冒破坏旧版本的风险。
  • 逐步淘汰:在新版本中移除过时的功能,给用户足够的时间迁移。

常见的版本策略有这几种:

  • URL 路径版本:/api/v1/users,直观,最常见
  • 查询参数版本:/api/users?api-version=1.0
  • 请求头版本:X-API-Version: 1.0
  • 媒体类型版本:Accept: application/json; v=1.0(GitHub 在用这种方式)

每种方式都有适用场景,没有绝对的优劣。

在 C# 生态中,长期以来的事实标准是 Swashbuckle.AspNetCore,但它并没有内置版本管理支持,需要配合 Asp.Versioning 来实现。

终于,在 .NET 10 中,微软推出了自己的 OpenAPI 库 Microsoft.AspNetCore.OpenApi,并且 Asp.Versioning v10 也正式支持了这个库,版本管理和文档生成终于可以无缝结合了。

上手 Microsoft.AspNetCore.OpenApi 和 Asp.Versioning

要使用 Microsoft.AspNetCore.OpenApi 和 Asp.Versioning 来实现 API 版本管理,首先需要安装相关 NuGet 包:

#package: Asp.Versioning.Http 10.0.0
#package: Asp.Versioning.Mvc 10.0.0
#package: Asp.Versioning.Mvc.ApiExplorer 10.0.0
#package: Microsoft.AspNetCore.OpenApi 10.0.0
#package: Scalar.AspNetCore 2.6.0

安装完成后,在 Program.cs 中进行如下配置:

services.AddApiVersioning(options =>{options.DefaultApiVersion = new ApiVersion(1, 0);options.AssumeDefaultVersionWhenUnspecified = true;options.ReportApiVersions = true;options.ApiVersionReader = new UrlSegmentApiVersionReader();}).AddMvc().AddApiExplorer(options =>{options.GroupNameFormat = "'v'V";options.SubstituteApiVersionInUrl = true;});services.AddOpenApi("v1", options =>
{options.ShouldInclude = apiDescription => apiDescription.GroupName == "v1";
});services.AddOpenApi("v2", options =>
{options.ShouldInclude = apiDescription => apiDescription.GroupName == "v2";
});app.MapOpenApi();
app.MapScalarApiReference(options =>
{options.WithTitle("Users API - {documentName}").AddDocuments(new[] { "v1", "v2" });
});

在上面的代码中,我们首先配置了 API 版本管理,指定了默认版本、版本读取方式等。然后,我们为每个版本配置了 OpenAPI 文档生成,确保每个版本都有独立的文档。最后,我们映射了 OpenAPI 和 Scalar API Reference 的路由。

控制器方面,我们可以使用特性来指定版本:

[ApiController]
[Route("api/v{version:apiVersion}/[controller]")]
[ApiVersion("1.0")]
public class UsersController : ControllerBase
{[HttpGet][MapToApiVersion("1.0")]public IActionResult GetV1(){return Ok(new { Version = "v1", Users = new[] { "Alice", "Bob" } });}
}[ApiController]
[Route("api/v{version:apiVersion}/[controller]")]
[ApiVersion("2.0")]
public class UsersV2Controller : ControllerBase
{[HttpGet][MapToApiVersion("2.0")]public IActionResult GetV2(){return Ok(new { Version = "v2", Users = new[] { "Alice", "Bob", "Charlie" } });}
}

通过上述配置,我们就实现了基于 URL 路径的 API 版本管理,并且每个版本都有独立的 OpenAPI 文档。

这里还使用了一个叫 Scalar 的库来生成 API 参考文档。Scalar 是一个专注于生成 API 参考文档的库,支持多版本文档生成和定制化配置。通过 Scalar,我们可以轻松地为每个 API 版本生成漂亮的参考文档,方便开发者查阅。

上一张 Scalar 的图(和本项目无关)
在这里插入图片描述

我把实验项目的代码放在了 GitHub 上,欢迎大家参考:
https://github.com/denglei1024/openapi-apiversion

如果这篇文章对你有帮助,欢迎点赞、在看、转发给更多 .NET 开发者 ❤️

http://www.jsqmd.com/news/759050/

相关文章:

  • 从零构建AI工程化项目:MLflow、DVC与Kubernetes实战指南
  • 使用 Python 快速接入 Taotoken 并调用 OpenAI 兼容大模型 API 的完整教程
  • Cortex-M52处理器AHB接口架构与优化实践
  • 别再死磕理论了!用Python手把手教你复现NSGA-II算法(附完整代码与可视化)
  • 零样本TTS与语音编辑技术解析
  • 终极指南:如何为ETS2/ATS构建智能车道辅助与插件系统
  • WeChatExporter终极指南:三步轻松导出你的微信聊天记录
  • 字节跳动豆包拟推付费服务,5088元年费能否跑通商业化道路?
  • 2026医疗行业GEO优化公司TOP6:对比+推荐,口碑榜+排名双维 - GEO优化
  • RevokeMsgPatcher完整指南:Windows平台微信QQ防撤回终极解决方案
  • FastJSON序列化性能与数据完整性的权衡:深入解读DisableCircularReferenceDetect特性
  • 如何高效管理桌面窗口:智能窗口布局实战指南
  • 为什么AnimateDiff是视频生成领域的革命性工具?
  • 5分钟快速配置:罗技鼠标宏实现PUBG完美压枪
  • Windows风扇控制新境界:5个步骤打造你的静音高性能电脑
  • REFramework技术深度解析:RE2非光追版启动崩溃问题的排查与修复
  • 2026年4月行业内正规的接地故障定位仪直销厂家口碑推荐,接地变柜,接地故障定位仪直销厂家怎么选择 - 品牌推荐师
  • 南宁哪家装修公司口碑好?本土老牌辉凡装饰工程有限公司 企业介绍 - 一个呆呆
  • 别再到处找了!FortiGate VM 7.4.2/7.2.6/7.0.13 各版本下载与部署指南(附避坑清单)
  • 基于大语言模型的Instagram私信AI聊天机器人开发与部署实战
  • 家庭NAS玩家必备:用Docker Compose一键部署Jackett,解锁400+资源站搜索
  • 2026 怀化黄金回收榜|雅韵金行位列榜一
  • Docker 27正式版AI容器调度全链路解析:从cgroups v2适配到Kubernetes CRD动态注入,实测吞吐提升47.3%
  • 终极暗黑2存档编辑器:重新定义游戏体验的完整指南
  • PCL RANSAC分割提取多个圆柱【2026最新版】
  • 为 Claude Code 编程助手配置 Taotoken 作为稳定的模型提供商
  • 新手也能懂的RSA解密实战:用Python和RSA Tool搞定BUUCTF那道rsarsa题
  • PyEcharts-Gallery:打破数据可视化学习壁垒的实战宝典
  • 阿里云 ECS CPU 使用率持续 100% 如何定位进程?
  • TFLite模型量化实战:如何把模型体积缩小4倍,推理速度提升2倍?