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;
  }

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

相关推荐
Loo国昌4 小时前
【LangChain1.0】第九阶段:文档处理工程 (LlamaIndex)
人工智能·后端·python·算法·langchain
毕设源码-朱学姐4 小时前
【开题答辩全过程】以 基于SpringBoot的律师事务所管理系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
愈努力俞幸运4 小时前
flask 入门 token, headers,cookie
后端·python·flask
毕设源码-朱学姐4 小时前
【开题答辩全过程】以 基于springboot的日用药品仓库管理系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
lkbhua莱克瓦246 小时前
深入理解HTTP协议:从理论到SpringBoot实践
网络·笔记·后端·网络协议·http·javaweb
古城小栈6 小时前
Rust复合类型 四大军阀:数、元、切、串
开发语言·后端·rust
+VX:Fegn08958 小时前
计算机毕业设计|基于springboot + vue酒店预订系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
JavaGuide8 小时前
IntelliJ IDEA 2026.1 EAP 发布!拥抱 Java 26,Spring Boot 4 深度支持!
java·后端·mysql·springboot·idea·大厂面试·javaguide
Zsh-cs8 小时前
苍穹外卖之Swagger+Knife4j在项目中的应用场景
swagger·knife4j·苍穹外卖
小北方城市网9 小时前
MySQL 索引优化实战:从慢查询到高性能
数据库·spring boot·后端·mysql·rabbitmq·mybatis·java-rabbitmq