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。
据我所知,API Explorer 不支持传统路由(这是 Swashbackle 的基础)。
我的解决方案是使用chsakell 的Swashbuckle.AspNetCore.SwaggerGen.ConventionalRouting包。
| 归档时间: |
|
| 查看次数: |
1022 次 |
| 最近记录: |