您现在的位置是:首页 > 文章详情

Asp.Net Core SwaggerUI 接入

日期:2019-07-21点击:321

Asp.Net Core SwaggerUI 接入
简单了解
swagger的目的简单来说就是,不用为每个接口手动写接口文档,因为它是根据接口自动生成的,接口更改时文档也同步更新,减少了手动更新的麻烦和遗漏。同时也提供了接口的调试等功能,你不用打开postman等接口测试软件来测试接口;如果有写备注的话,接口、入参和输出都有详细的备注说明,调用接口的人也能更加直观的读懂接口。沟通效率和工作效率也会大大提升。

Swagger接入的步骤:
注册Swagger生成器:services.AddSwaggerGen().
插入中间件,将生成的Swagger公开为JSON节点:app.UseSwagger()
插入Swagger-UI中间件,将指定的swagger json端点为其提供支持:app.UseSwaggerUI()
一、添加Nuget包
Package Manager : Install-Package Swashbuckle.AspNetCore

CLI : dotnet add package Swashbuckle.AspNetCore
二、注册swagger文档服务
注意
如果mvc使用的是services.AddMvcCore(),则需要手动添加ApiExplorer,因为SwashBuckle强烈依赖于ApiExplorer,ApiExplorer用来发现控制器中的接口方法。需要手动添加。如:
services.AddMvcCore().AddApiExplorer();

如果使用的是services.AddMvc(),则不需要再进行注册。因为AddMvc()中已经添加了ApiExplorer。如:

public static IMvcBuilder AddMvc(this IServiceCollection services) { if (services == null) throw new ArgumentNullException(nameof (services)); IMvcCoreBuilder builder = services.AddMvcCore(); builder.AddApiExplorer();//在这里 builder.AddAuthorization(); MvcServiceCollectionExtensions.AddDefaultFrameworkParts(builder.PartManager); builder.AddFormatterMappings(); builder.AddViews(); builder.AddRazorViewEngine(); builder.AddRazorPages(); builder.AddCacheTagHelper(); builder.AddDataAnnotations(); builder.AddJsonFormatters(); builder.AddCors(); return (IMvcBuilder) new MvcBuilder(builder.Services, builder.PartManager); }

什么时候用AddMvc(),什么时候用AddMvcCore()呢?
通过AddMvc()的方法中我们应该可以发现,里面有添加View、Razor和TagHelper服务,这些在WebApi项目中是用不到的。所以:
1).如果你的项目是mvc web程序,则使用AddMvc().
2).如果的项目是webapi,则使用AddMvcCore(),然后酌情添加需要的其它服务;当然使用AddMvc()也没有问题。

添加Swagger服务
services.AddSwaggerGen(options =>
{

options.SwaggerDoc(AppDefaults.ApiDocumentName, new Info { Title = AppDefaults.ApiDocumentTitle, Description = AppDefaults.ApiDocumentDescription, Version = typeof(Startup).Assembly.GetName().Version.ToString() }); //加载注释文件 Directory.GetFiles(Environment.ContentRootPath, "*.xml", SearchOption.AllDirectories) .ToList() .ForEach(f => options.IncludeXmlComments(f));

});
三、添加管道
//生成swagger-json文件,并重定义swagger-json文件路由模板,这里我修改了 swagger-json 的路由模板。
//如果不自定义的话,默认是 swagger/{documentName}/swagger.json
app.UseSwagger(options => options.RouteTemplate = "{documentName}/swagger.json");

app.UseSwaggerUI(options =>
{

//指定生成swagger-json文件路径,为SwaggerUI提供数据。 //如果上边路由模板没有自定义,则完成路径是 /swagger/{AppDefaults.ApiDocumentName}/swagger.json options.SwaggerEndpoint($"/{AppDefaults.ApiDocumentName}/swagger.json", AppDefaults.ApiDocumentName); //自定义SwaggerUI页面路由前缀 //地址栏输入 http://loacalhost:5000/lxp 就可以打开SwaggerUI页面 options.RoutePrefix = "lxp";

});
四、定义接口
如果想要控制器在Swagger中显示,所有控制器必须使用属性路由
接口方法要使用 Http 属性和 From 特性标注
例如:

[Route("[controller]")] [ApiController] public class ValuesController : ControllerBase { [HttpGet("name")] public async Task<ActionResult<string>> GetNameAsync([FromQuery] string name) { if (!string.IsNullOrEmpty(name)) { ModelState.TryAddModelError(nameof(name), $"{nameof(name)} can not be empty"); } if (!ModelState.IsValid) { return BadRequest(ModelState); } return await Task.FromResult(name); } }

补充:
AppDefaults 是我定义一个常量的类
原文地址https://www.cnblogs.com/imlxp/p/11223952.html

原文链接:https://yq.aliyun.com/articles/710180
关注公众号

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。

持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。

文章评论

共有0条评论来说两句吧...

文章二维码

扫描即可查看该文章

点击排行

推荐阅读

最新文章