应无所住,而生其心
排名
6
文章
6
粉丝
16
评论
8
net core webapi post传递参数
庸人 : 确实坑哈,我也是下班好了好几次,发现后台传递对象是可以的,但...
百度编辑器自定义模板
庸人 : 我建议换个编辑器,因为现在百度富文本已经停止维护了,用tinymec...
ICP备案 :渝ICP备18016597号-1
网站信息:2018-2025TNBLOG.NET
技术交流:群号656732739
联系我们:contact@tnblog.net
公网安备:50010702506256
欢迎加群交流技术

.NET Core使用NSwagger实现Api文档生成与版本控制。生成xml文件

9897人阅读 2021/5/6 15:10 总访问:5185870 评论:0 收藏:2 手机
分类: .NET Core

参考代码下载地址:https://download.tnblog.net/resource/index/ba55ad0850ca4b71bc56855d0b4782d1


一:下载NSwag环境

Install-Package NSwag.AspNetCore -version 13.10.8

或使用PackageReference安装:

  1. <PackageReference Include="NSwag.AspNetCore" Version="13.10.8" />

要注意版本,不接版本号是默认下载最新版本是要5.0支持的,所以要看自己当前的环境来选择下载


如果不知道,可以在包管理器看到不同版本所依赖的环境,如下可以看到目前最新版13.11.1是需要.net5.0环境的(这个可能是以下环境都支持而不是所有都要满足....所以可以具体测试一下)




二:注入与添加NSwag中间件

在 Startup.ConfigureServices 方法中,注册所需的 Swagger 服务:

  1. public void ConfigureServices(IServiceCollection services)
  2. {
  3.     // 注入 Swagger 服务
  4.     services.AddSwaggerDocument();
  5. }

在 Startup.Configure 方法中,启用中间件为生成的 Swagger 规范和 Swagger UI 提供服务:

  1. public void Configure(IApplicationBuilder app)
  2. {
  3.     // 注册 Swagger 和 Swagger UI 中间件
  4.     app.UseOpenApi();
  5.     app.UseSwaggerUi3();
  6.     app.UseMvc();
  7. }


三:尝试访问,查看生成的api文档

访问地址:

http://localhost:<port>/swagger,以查看 Swagger UI。

http://localhost:<port>/swagger/v1/swagger.json,以查看 Swagger 规范。


如下图可以看到我们的接口文档被正确的生成了(这里会涉及到一些注释信息在下一小节分享):





四:给api文档加上注释

在第三步我们可以看到生成的注释其实是经过我们处理的,要想生成的api文档包含注释,我们可以在代码中使用标准的方法、类注释即可。

类注释:

方法注释:


项目右键-->属性-->生成。勾上xml文档文件,它会生成基于xml的注释:

勾上:

Swashbuckle需要使用IncludeXmlComments手动加载,NSwag不需要手动加载默认xml注释文件和它对应点dll应该放在同一目录且同名才能完成加载!

所以本地调试的时候可以把路径写成bin\bebug下面

如果是Swashbuckle的话,需要手动加载使用如下代码即可(xml文档文件的位置使用默认的地方即可):
  1. context.Services.AddSwaggerGen(c =>
  2. {
  3.     c.SwaggerDoc("v1"new OpenApiInfo { Title = "蔚宇科技.Api", Version = "v1" });
  4.     // 获取xml文件名
  5.     var xmlFile = $"{Assembly.GetExecutingAssembly().GetName().Name}.xml";
  6.     // 获取xml文件路径
  7.     var xmlPath = Path.Combine(AppContext.BaseDirectory, xmlFile);
  8.     //是否显示注释
  9.     c.IncludeXmlComments(xmlPath, true);
  10. });


然后运行查看:
可以看到具体的方法有注释了

但是控制器标签栏还是没有注释,这是因为NSwag的控制器标签默认从OpenApiTagAttribute中读取   

然后运行就能看到注释了

当然使用这种特性的方式和我们平时正常使用的方式有出入,我们还是希望从xml生成的话也很简单,我们可以修改这个默认行为,settings有一个UseControllerSummaryAsTagDescription属性,将它设置成 true就可以从xml注释文件中加载描述了:
  1.     services.AddOpenApiDocument(settings =>
  2.     {
  3.         ...
  4.         //可以设置从注释文件加载,但是加载的内容可被OpenApiTagAttribute特性覆盖
  5.         settings.UseControllerSummaryAsTagDescription = true;
  6.     });
至于接口文档的title申明,版本号说明,简单描述等也可以在注入的时候设置即可:
  1. //添加NSwag
  2. services.AddSwaggerDocument(a =>
  3. {
  4.     a.DocumentName = "v1";
  5.     a.Version = "v0.0.1";
  6.     a.Title = "TNBLOG.APP接口项目";
  7.     a.Description = "接口文档说明";
  8.     a.UseControllerSummaryAsTagDescription = true;
  9. });
还有开启了注释后,如果没有注释会出现cs1591的警告

如果你觉得很烦,可以在配置中去掉就行。如下图所示,加一个1591即可



五:结合NSwag实现api版本控制

当然前提是你的api项目本身是支持版本控制的,net core webapi实现版本控制可以参考:https://www.tnblog.net/aojiancc2/article/details/2823

然后我们需要借助Mvc.Versioning.ApiExplorer这个库来和NSwag结合使用

先下载ApiExplorer:

  1.     <PackageReference Include="Microsoft.AspNetCore.Mvc.Versioning.ApiExplorer" Version="3.2.1" />

自己注意版本,版本不能过低,不然不能支持AddVersionedApiExplorer这个方法,也不能过高可能你的环境不支持

然后在ConfigureServices中加入相关配置

首先注入:ApiExplorer

  1. //版本不能过低,不然不能支持这个方法
  2. services.AddVersionedApiExplorer(option =>
  3. {          
  4.     option.GroupNameFormat = "'v'V";// 版本名的格式:v+版本号
  5.     option.AssumeDefaultVersionWhenUnspecified = true;
  6. });

然后通过ApiExplorer去获取API版本信息,然后循环注入swagger文档即可,有几个版本就会注入几次(注意要先进行上面的那步注入ApiExplorer不然你都没有注入就从容器中获取IApiVersionDescriptionProvider就会报错)

  1. //获取webapi版本信息,用于swagger多版本支持 
  2. var provider = services.BuildServiceProvider().GetRequiredService<IApiVersionDescriptionProvider>();
  3. //遍历版本信息给不同版本添加NSwag支持,如果只写一个就只有一份
  4. foreach (var description in provider.ApiVersionDescriptions)
  5. {
  6.     //添加NSwag
  7.     services.AddSwaggerDocument(a =>
  8.     {
  9.         a.DocumentName = description.GroupName;
  10.         a.Version = description.GroupName;
  11.         a.Title = "TNBLOG.APP接口项目";
  12.         a.Description = "接口文档说明";
  13.         a.ApiGroupNames = new string[] { description.GroupName };
  14.         a.UseControllerSummaryAsTagDescription = true;
  15.     });
  16. }

效果如下,这样就可以实现版本控制了:


版本控制后调用接口的时候需要接版本号:
swagger测试的时候:

uni-app调用的时候可以这样加header:



tip:也可以使用Swashbuckle.AspNetCore这个库

欢迎加群讨论技术,1群:677373950(满了,可以加,但通过不了),2群:656732739。有需要软件开发,或者学习软件技术的朋友可以和我联系~(Q:815170684)

评价

net core 使用 EF Code First

下面这些内容很老了看这篇:https://www.tnblog.net/aojiancc2/article/details/5365 项目使用多层,把数据库访问...

.net mvc分部页,.net core分部页

.net分部页的三种方式第一种:@Html.Partial(&quot;_分部页&quot;)第二种:@{ Html.RenderPartial(&quot;分部页&quot;);}...

StackExchange.Redis操作redis(net core支持)

官方git开源地址https://github.com/StackExchange/StackExchange.Redis官方文档在docs里边都是官方的文档通过nuget命令下...

.net core 使用session

tip:net core 2.2后可以直接启用session了,不用在自己添加一次session依赖,本身就添加了使用nuget添加引用Microsoft.AspN...

通俗易懂,什么是.net?什么是.net Framework?什么是.net core?

朋友圈@蓝羽 看到一篇文章写的太详细太通俗了,搬过来细细看完,保证你对.NET有个新的认识理解原文地址:https://www.cnblo...

asp.net core2.0 依赖注入 AddTransient与AddScoped的区别

asp.net core主要提供了三种依赖注入的方式其中AddTransient与AddSingleton比较好区别AddTransient瞬时模式:每次都获取一...

.net core 使用 Kestrel

Kestrel介绍 Kestrel是一个基于libuv的跨平台web服务器 在.net core项目中就可以不一定要发布在iis下面了Kestrel体验可以使...

net core使用cookie

net core中可以使用传统的cookie也可以使用加密的cookieNET CORE中使用传统cookie设置:HttpContext.Response.Cookies.Appe...

net core项目结构简单分析

一:wwwrootwwwroot用于存放网站的静态资源,例如css,js,图片与相关的前端插件等lib主要是第三方的插件,例如微软默认引用...

net core使用EF之DB First

一.新建一个.net core的MVC项目新建好项目后,不能像以前一样直接在新建项中添加ef了,需要用命令在添加ef的依赖二.使用Nug...

.net core使用requestresponse下载文件下载excel等

使用request获取内容net core中request没有直接的索引方法,需要点里边的Query,或者formstringbase64=Request.Form[&quot;f...

iframe自适应高度与配合net core使用

去掉iframe边框frameborder=&quot;0&quot;去掉滚动条scrolling=&quot;no&quot;iframe 自适应高度如果内容是固定的,那么就...

net core启动报错Unable to configure HTTPS endpoint. No server certificate was specified

这是因为net core2.1默认使用的https,如果使用Kestrel web服务器的话没有安装证书就会报这个错其实仔细看他的错误提示,其...

net core使用url编码与解码操作

net core中暂时还没有以前asp.net与mvc中的server对象。获取url的编码与解码操作不能使用以前的server对象来获取。使用的是...

下载net core

官方下载地址:https://dotnet.microsoft.com/download 进来之后就可以看到最新的下载版本可以直接点击下载,也可以下载其...

net core使用依赖注入来装载EF的上下文对象

妹子情人节快乐~.net core中用了不少的依赖注入,官方文档中也推荐使用。这样使用依赖注入来管理ef对象,还是比较科学,比如...