全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

ASP.NET Core怎么实现API版本控制 ASP.NET Core API Versioning教程

推荐使用 Microsoft.AspNetCore.Mvc.Versioning 包实现 ASP.NET Core API 版本控制,支持 URL、查询参数、请求头等多种版本标识方式,需在 Program.cs 中注册服务并配置默认版本、弃用提示等,控制器通过 [ApiVersion] 特性声明版本支持。

ASP.NET Core 实现 API 版本控制,推荐使用官方支持的 Microsoft.AspNetCore.Mvc.Versioning 包,它轻量、灵活,与 MVC 深度集成,支持 URL、查询参数、请求头等多种版本标识方式。

安装并启用版本控制服务

Program.cs 中注册服务并配置基础行为:

  • 通过 AddApiVersioning 启用版本控制,设置默认版本(如 1.0)和是否报告支持的版本
  • 可选启用 AssumeDefaultVersionWhenUnspecified = true,让无版本请求默认走 v1
  • 若需返回 api-supported-versionsapi-deprecated-versions 响应头,开启 ReportApiVersions = true
示例:
builder.Services.AddApiVersioning(options =>
{
    options.DefaultApiVersion = new ApiVersion(1, 0);
    options.AssumeDefaultVersionWhenUnspecified = true;
    options.ReportApiVersions = true;
});

在控制器中声明版本支持

使用 [ApiVersion] 特性标注控制器或具体 Action,支持多个版本同时存在:

  • 单个控制器支持多版本:加多个 [ApiVersion("1.0")][ApiVersion("2.0")]
  • 不同控制器处理不同版本:如 ProductsControllerV1ProductsControllerV2,都路由到 /api/products
  • 配合 [MapToApiVersion("2.0")] 可将某个 Action 限定只响应 v2 请求
注意:必须为每个版本提供至少一个匹配的 endpoint,否则会返回 400 或 404。

选择版本识别方式(URL / Query / Header)

默认通过请求头 api-version 识别,但更常见的是 URL 路径(如 /api/v1/products)或查询参数(如 /api/products?api-version=1.0):

  • URL 路径:配置 options.ApiVersionReader = new UrlSegmentApiVersionReader();,再用 [Route("api/v{version:apiVersion}/[controller]")]
  • 查询参数:用 new QueryStringApiVersionReader("api-version")
  • 请求头:默认即支持,客户端传 api-version: 2.0
  • 也可组合使用,如优先读 URL,降级读 Header

处理弃用与兼容性提示

对已废弃的版本,可通过特性明确标记,并由框架自动注入响应头:

  • 给控制器加 [ApiVersion("1.0", Deprecated = true)]
  • 启用 ReportApiVersions = true 后,v1 接口响应头会包含 api-deprecated-versions: 1.0
  • 客户端可根据该头决定是否提醒用户升级,服务端无需手动拦截或返回特殊状态码

基本上就这些。不复杂但容易忽略细节,比如忘了注册服务、没配路由模板、或多个版本控制器冲突——调试时留意日志里 ApiVersionMatcherPolicy 的匹配结果即可。


# 路由  # microsoft  # 状态码  # .net  # mvc  # 接口  # 多个  # 推荐使用  # 的是  # 客户端  # 也可  # 可选  # 再用  # 可将  # 可通过  # 并由 


相关文章: 广州网站设计制作一条龙,广州巨网网络科技有限公司是干什么的?  如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南  深圳 网站制作,深圳招聘网站哪个比较好一点啊?  网站制作价目表怎么做,珍爱网婚介费用多少?  如何高效生成建站之星成品网站源码?  建站与域名管理如何高效结合?  贸易公司网站制作流程,出口贸易网站设计怎么做?  建站之星五站合一营销型网站搭建攻略,流量入口全覆盖优化指南  宝塔建站助手安装配置与建站模板使用全流程解析  建站主机CVM配置优化、SEO策略与性能提升指南  C++如何编写函数模板?(泛型编程入门)  如何在IIS中新建站点并解决端口绑定冲突?  建站之星安装模板失败:服务器环境不兼容?  如何在阿里云域名上完成建站全流程?  专业网站设计制作公司,如何制作一个企业网站,建设网站的基本步骤有哪些?  企业宣传片制作网站有哪些,传媒公司怎么找企业宣传片项目?  开心动漫网站制作软件下载,十分开心动画为何停播?  建站主机服务器选型指南与性能优化方案解析  在线流程图制作网站手机版,谁能推荐几个好的CG原画资源网站么?  建站之星CMS五站合一模板配置与SEO优化指南  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?  php条件判断怎么写_ifelse和switchcase的使用区别【对比】  建站之星如何取消后台验证码生成?  创业网站制作流程,创业网站可靠吗?  如何在阿里云服务器自主搭建网站?  专业网站制作企业网站,如何制作一个企业网站,建设网站的基本步骤有哪些?  北京网站制作的公司有哪些,北京白云观官方网站?  儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?  代刷网站制作软件,别人代刷火车票靠谱吗?  建站主机功能解析:服务器选择与快速搭建指南  如何在云指建站中生成FTP站点?  如何快速搭建高效可靠的建站解决方案?  香港服务器租用每月最低只需15元?  如何快速搭建高效简练网站?  官网建站费用明细查询_企业建站套餐价格及收费标准指南  网站制作的软件有哪些,制作微信公众号除了秀米还有哪些比较好用的平台?  如何通过服务器快速搭建网站?完整步骤解析  商务网站制作工程师,从哪几个方面把握电子商务网站主页和页面的特色设计?  建站主机是否等同于虚拟主机?  太原网站制作公司有哪些,网约车营运证查询官网?  建站之星北京办公室:智能建站系统与小程序生成方案解析  官网自助建站系统:SEO优化+多语言支持,快速搭建专业网站  建站主机是什么?如何选择适合的建站主机?  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  已有域名和空间,如何快速搭建网站?  长沙企业网站制作哪家好,长沙水业集团官方网站?  建站之星如何快速解决建站难题?  linux top下的 minerd 木马清除方法  如何在阿里云通过域名搭建网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。