首页
/ Swashbuckle.AspNetCore 控制器排序问题解决方案

Swashbuckle.AspNetCore 控制器排序问题解决方案

2025-06-08 15:43:07作者:卓炯娓

问题背景

在使用 Swashbuckle.AspNetCore 为 ASP.NET Core 应用生成 API 文档时,开发者经常会遇到控制器排序不符合预期的问题。特别是在多项目结构中,当控制器分布在不同的程序集(如共享库和主应用)时,默认的排序行为可能无法满足需求。

典型场景

假设我们有以下控制器结构:

  1. 共享库中的 PingController(Xxx.Yyy.Common.Controllers.Ping.PingController)
  2. 主应用中的 HealthChecksController 和 SamplesController

期望的排序顺序是:

  • HealthChecks
  • Ping
  • Samples

常见误区

许多开发者会尝试使用 OrderActionsBy 方法来控制排序:

options.OrderActionsBy(
    apiDesc => 
        $"{apiDesc.ActionDescriptor.RouteValues["controller"]}_{apiDesc.RelativePath}_{apiDesc.HttpMethod}"
);

这种方法虽然能对控制器内部的端点方法进行排序,但对控制器本身的排序无效。这是因为 OrderActionsBy 主要影响的是同一控制器下各个操作的排序,而非控制器级别的排序。

解决方案

方案一:使用 DocumentFilter(不推荐)

可以通过实现 IDocumentFilter 接口来手动指定标签顺序:

public class ApiControllerTagDescriptions : IDocumentFilter
{
    public void Apply(OpenApiDocument swaggerDoc, DocumentFilterContext context)
    {
        swaggerDoc.Tags = new List<OpenApiTag>
        {
            new OpenApiTag{ Name = "HealthChecks", Description = "HealthChecks" },
            new OpenApiTag{ Name = "Ping", Description = "Ping" },
            new OpenApiTag{ Name = "Samples", Description = "Samples" }
        };
    }
}

然后在配置中注册:

options.DocumentFilter<ApiControllerTagDescriptions>();

缺点:这种方法需要硬编码控制器名称,维护成本高,特别是在多项目或频繁变更的场景下。

方案二:配置 SwaggerUI 排序选项(推荐)

更优雅的解决方案是直接配置 SwaggerUI 的排序行为:

services.Configure<SwaggerUIOptions>(options =>
{
    // 控制器或标签级别的排序(UI中的顶层分组)
    options.ConfigObject.AdditionalItems["tagsSorter"] = "alpha";
    
    // 控制器内部操作的排序(端点方法)
    options.ConfigObject.AdditionalItems["operationsSorter"] = "alpha";
});

参数说明

  • "alpha":按字母顺序排序(适用于路径或标签)
  • "method":按HTTP方法排序(仅适用于操作)
  • 默认/省略:使用规范文档中的原始顺序

技术原理

这种解决方案之所以有效,是因为它直接配置了 SwaggerUI 的客户端排序行为。SwaggerUI 提供了内置的排序器:

  1. tagsSorter:控制顶层标签/控制器的排序
  2. operationsSorter:控制每个控制器内部操作的排序

通过设置这些参数,我们可以覆盖默认的排序行为,而无需修改生成的 OpenAPI 规范文档本身。

最佳实践

  1. 对于简单的字母排序需求,使用 "alpha" 即可满足大多数场景
  2. 如果需要更复杂的排序逻辑,可以编写自定义的 JavaScript 排序函数
  3. 在多项目环境中,这种配置方式比硬编码控制器名称更易于维护
  4. 建议将 Swagger 配置集中管理,便于统一维护和更新

注意事项

  1. 此解决方案主要影响 SwaggerUI 的展示顺序,不会改变生成的 OpenAPI 规范文档
  2. 如果 API 文档会被其他工具使用,需要考虑那些工具可能使用不同的排序逻辑
  3. 在 .NET 8 环境中验证通过,但原理适用于其他版本的 ASP.NET Core

通过这种配置方式,开发者可以轻松实现控制器的预期排序,同时保持代码的简洁性和可维护性。

登录后查看全文
热门项目推荐

热门内容推荐

最新内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
176
261
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
858
509
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
182
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
257
300
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
331
1.08 K
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
397
370
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
83
4
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
kernelkernel
deepin linux kernel
C
22
5