Asp.net core用Swashbuckle.AspNetCore库出现错误信息:No operations defined in spec!

最近在搞个框架进行模块化的,在主程序加载程序集里的Controllers,启动程序在浏览器访问http://localhost:5200/swagger/index.html页面的API出现错误信息:

No operations defined in spec!

1,后来新建一个项目进行一一排查

先浏览器调试请求的http://localhost:5200/swagger/Sys/swagger.json里面返回的jsond的paths没有数据。证明获取不了Controllers的数据。

对比一下代码里面SwaggerDoc方法里参数module.Name与 c.SwaggerEndpoint方法的{module.Name}一致;

cs 复制代码
  builder.Services.AddSwaggerGen(
    doc =>
    {
        // module.Name 
        doc.SwaggerDoc(module.Name, new OpenApiInfo
        {
            Title = $"{module.Name} API",
            Version = module.Version,
            Description = module.Description
        });
        
        doc.AddSecurityDefinition("Bearer", new OpenApiSecurityScheme
        {
            Type = SecuritySchemeType.ApiKey,
            In = ParameterLocation.Header,
            Name = "Authorization"
        });
        
        doc.AddSecurityRequirement("Bearer", new List<string>());
    });   
cs 复制代码
app.UseSwaggerUI(c =>
{
    foreach (var module in Shared.Extensions.ModuleExtensions.Modules)
    {
        if (module.IsApplicationPart)
        {
            c.SwaggerEndpoint($"/swagger/{module.Name}/swagger.json", $"{module.Name} API");
        }
    }

});

2,必须加载Controllers的数据,要不然也是获取不了Controllers的数据。

cs 复制代码
  /// <summary>
  /// 向Mvc添加模块中的控制器
  /// </summary>
  public static IMvcBuilder AddModuleControllers(this IMvcBuilder mvcBuilder, string contentRootPath)
  {

      Shared.Extensions.ModuleExtensions.Modules = Shared.Extensions.ModuleExtensions.GetModules();
      foreach (var module in Shared.Extensions.ModuleExtensions.Modules)
      {
          //根据Modules文件夹和模块ID加载模块程序集  
          var moduleFolder = new DirectoryInfo(Path.Combine(Shared.Extensions.ModuleExtensions.ContentRootPath, $@"Modules\{module.Id}\{module.Id}.dll"));
          if (File.Exists(moduleFolder.ToString()))
          {
              var assembly = Assembly.LoadFrom(moduleFolder.ToString());
              mvcBuilder.AddApplicationPart(assembly);
          }
      }

      return mvcBuilder;
  }

希望我的经历能帮助大家。

相关推荐
LYFlied3 小时前
在AI时代,前端开发者如何构建全栈开发视野与核心竞争力
前端·人工智能·后端·ai·全栈
用户47949283569154 小时前
我只是给Typescript提个 typo PR,为什么还要签协议?
前端·后端·开源
Surpass余sheng军4 小时前
AI 时代下的网关技术选型
人工智能·经验分享·分布式·后端·学习·架构
JosieBook4 小时前
【Spring Boot】Spring Boot调用 WebService 接口的两种方式:动态调用 vs 静态调用 亲测有效
java·spring boot·后端
喵个咪5 小时前
开箱即用的 GoWind Admin|风行,企业级前后端一体中后台框架:基于 GORM 从零实现新服务
后端·go·orm
a努力。6 小时前
【基础数据篇】数据等价裁判:Comparer模式
java·后端
开心猴爷6 小时前
苹果App Store应用程序上架方式全面指南
后端
小飞Coding6 小时前
三种方式打 Java 可执行 JAR 包,你用对了吗?
后端
bcbnb6 小时前
没有 Mac,如何在 Windows 上架 iOS 应用?一套可落地的工程方案
后端