.NET Core API文档管理组件 Swagger
Swagger
这个优秀的开源项目相信大家都用过,不多介绍了,这里简单记录一下使用过程。
开源地址:https://github.com/domaindrivendev/Swashbuckle.AspNetCore
在项目中添加组件
下面用最少的代码完成接入,在Startup
启动项中配置。
这样便完成了,swagger
会自动发现我们在controller
中写的api,默认打开页面为:~/swagger
。
同时还可以让其支持分组展示,只需要像上面一样配置多个节点信息接口,如下面代码:
如果在控制器中不指定接口的分组名称,那么每个分组都会显示这个接口,如果需要单独指定可以使用特性[ApiExplorerSettings(GroupName = "v1")]
这样。
如果想要显示接口的注释,模型的注释等信息,需要我们将对应的项目设置输出XML文件,并在代码中使用options.IncludeXmlComments(xxx.xml)
即可。
下面来说一下swagger
的一些其它功能,当我们接口开启了JWT
方式的认证,默认swagger
是不支持的,需要我们手动去适配一下。
需要额外添加一个组件
现在UI界面便会出现小绿锁,这样就可以很方便的在swagger
上进行需要授权的接口调试工作了。
同时swagger
还支持一些高级操作,比如自定义UI界面、注入JS、CSS代码,因为这个用的不是很多,实际要用的时候可以去GitHub查看使用方法。
这里还要说一下swagger
的过滤器,我们可以实现IDocumentFilter
接口,来实现自定义的接口排序,个性化接口描述,以及各种骚操作,比如我们想要隐藏某些API,当然隐藏API可以使用.NET Core 的特性[ApiExplorerSettings(IgnoreApi = true)]
实现。
这里隐藏是指不在swagger
UI中显示,实际接口还是存在的。
上面这段代码,使用了abp框架搭建的项目,abp默认实现了一部分接口,如果我们不需要的话就可以使用上面的方式进行过滤。
最后一点,如果我们用了第三方框架,像上面说的abp,或者使用了动态API生成的组件,比如:Plus.AutoApi
,想要在swagger
中显示出api接口,需要添加下面这句代码。
swagger
推出的同时还推出了一款工具ReDoc
,下面也简单介绍一下。
ReDoc
和swagger
比较类似,只是一个文档展示工具,不提供接口调试的功能。
他们的使用方式基本一致,先在项目中添加一下组件
在OnApplicationInitialization
中直接添加一句配置即可。
它支持多种参数选项,可以自行查看,默认打开页面为:~/api-docs
,下面是他的UI界面。
__EOF__

本文链接:https://www.cnblogs.com/meowv/p/13614273.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?