ASP.Net MVC - Swashbuckle无法识别任何控制器
创始人
2024-09-16 08:31:50
0

问题描述: 在ASP.NET MVC项目中使用Swashbuckle生成API文档时,Swashbuckle无法识别任何控制器。

解决方法:

  1. 确保Swashbuckle及其依赖项已正确安装到项目中。可以通过NuGet包管理器或手动添加引用来安装Swashbuckle。

  2. 在Global.asax.cs文件中注册Swagger配置。在Application_Start方法中添加以下代码:

protected void Application_Start()
{
    // ...

    GlobalConfiguration.Configure(WebApiConfig.Register);

    // Register Swashbuckle
    GlobalConfiguration.Configuration
        .EnableSwagger(c =>
        {
            c.SingleApiVersion("v1", "My API");
        })
        .EnableSwaggerUi();
}
  1. 确保控制器类上已添加了[RoutePrefix]和[Route]特性。例如:
[RoutePrefix("api/users")]
public class UsersController : ApiController
{
    // ...

    [HttpGet]
    [Route("{id}")]
    public IHttpActionResult GetUser(int id)
    {
        // ...
    }

    // ...
}
  1. 确保WebApiConfig.cs中已启用了Web API路由。在Register方法中添加以下代码:
public static void Register(HttpConfiguration config)
{
    // ...

    // Enable attribute routing
    config.MapHttpAttributeRoutes();

    // ...
}
  1. 确保项目中的所有依赖项已正确安装,并且项目能够成功构建。

  2. 启动项目并访问Swagger UI,以查看是否能够正确显示API文档。访问地址通常为:http://localhost:{port}/swagger

如果仍然无法识别控制器,请检查项目中是否存在其他可能导致冲突的配置或代码。

相关内容

热门资讯

不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
安卓文字转语音tts没有声音 安卓文字转语音TTS没有声音的问题在应用中比较常见,通常是由于一些设置或者代码逻辑问题导致的。本文将...
APK正在安装,但应用程序列表... 这个问题可能是由于以下原因导致的:应用程序安装的APK文件可能存在问题。设备上已经存在同名的应用程序...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
报告实验.pdfbase.tt... 这个错误通常是由于找不到字体文件或者文件路径不正确导致的。以下是一些解决方法:确认字体文件是否存在:...