使用常规路由时不进行swagger操作

bpi*_*iec 5 routes swagger swashbuckle.aspnetcore

我的目标是 .NET Core 2.1,我不想使用这些Route属性,而是使用默认路由(所谓的常规路由)。这是我的Startup代码:

public class Startup
{
    public Startup(IConfiguration configuration)
    {
        Configuration = configuration;
    }

    public IConfiguration Configuration { get; }

    public void ConfigureServices(IServiceCollection services)
    {
        services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_1);

        services.AddSwaggerGen(c =>
        {
            c.SwaggerDoc("v1", new OpenApiInfo { Title = "API V1", Version = "v1" });
        });
    }

    public void Configure(IApplicationBuilder app, IHostingEnvironment env)
    {
        app.UseSwagger();

        app.UseMvc(routes =>
        {
            routes.MapRoute(
                name: "default",
                template: "api/{controller}/{action}");
        });
    }
}
Run Code Online (Sandbox Code Playgroud)

控制器很简单:

public class ValuesController : ControllerBase
{
    [HttpGet]
    public ActionResult<IEnumerable<string>> Get()
    {
        return new[] { "value1", "value2" };
    }
}
Run Code Online (Sandbox Code Playgroud)

我可以去https://myurl/api/values/get,它可以工作(返回一个数组)。但是,当我打开时swagger.json,没有定义任何操作:

{
  "openapi": "3.0.1",
  "info": {
    "title": "API V1",
    "version": "v1"
  },
  "paths": { },
  "components": { }
}
Run Code Online (Sandbox Code Playgroud)

如何让 swagger 识别传统路由?我正在使用 Swashbuckle 5.5.1 来生成 swagger。

bpi*_*iec 6

据我所知,API Explorer 不支持传统路由(这是 Swashbackle 的基础)。

我的解决方案是使用chsakell 的Swashbuckle.AspNetCore.SwaggerGen.ConventionalRouting包。