懒得写文档,swagger文档导出来不香吗

摘要:
离线文档swagger已经很方便了,我们为什么还需要离线文档?本文将聚焦于如何将swaggerUI导出离线文档。可是总有些时候,遇到一些难缠的,又不讲道理,偏偏觉得将Swagger文档地址丢给客户会不够正式!实现方式获取Swagger接口文档的Json文件解析Json文件数据填充到Html的表格中根据生成的html转work文档这就需要在swagger文档代码中做一些扩展。

导航

  • 前言
  • 离线文档
    • 1 保存为html
    • 2 导出成pdf文档
    • 3 导出成Word文档
  • 参考

前言

  早前笔者曾经写过一篇文章《研发团队,请管好你的API文档》。团队协作中,开发文档的重要性,这里就不再赘述,今天的话题集中在如何进一步提升更加高效的使用文档。

离线文档

  swagger已经很方便了,我们为什么还需要离线文档?公司同一个项目组,一般只要集成了swagger基本就够了,但是难免会有跨组,甚至会有公司对外合作的项目。特别是在"微服务大行其道的今天",多个团队之间,因为分工不同,权限不同,往往不能互相访问各个项目的swagger文档,通常的做法有以下几种:

  • 搭建统一的接口文档管理系统

    每个项目组的都要将各自的接口手动编写到归档到这里,需要查看,把人拉入组织即可查看。

  • 代码即文档

    提供源代码。同一个项目开发开发者。很多小公司就是这样。没有文档,只有源码。

  • 离线文档
    将文档导出成excel,docx,html等形式,对外输出,比如给第三方调用。

  本文将聚焦于如何将swaggerUI导出离线文档。

  笔者尝试了以下三种方式。

1 保存为html

Web开发者都知道,只要是网页你都可以另存为静态网页。

使用场景

然后,右键用谷歌浏览器打开

使用场景

当我运行我的代码时,它出错了:

swagger-ui-bundle.js:6 Fetch API cannot load file:///C:/swagger/v1/swagger.json. URL scheme must be "http" or "https" for CORS request.

  很明显和swagger.json有关系,还好对swagger有所了解。果断通过访问 http://localhost:5000/swagger/v1/swagger.json 下载swagger.json,并放在指定位置。

使用场景

  再次运行,报错和刚才一样。这是跨源资源共享问题。
有两种处理办法:

  • 使用网络服务器。

    要为静态html/js文件运行一个简单的Web服务器。

  • 更改您的chrome启动参数,并让它知道您要忽略此安全功能。

详细请查阅:https://www.codenong.com/50445639/

这里我使用的是IIS服务器,将js和html一同部署在IIS上,如下:

  • 更改您的chrome启动参数,并让它知道您要忽略此安全功能。

使用场景

  部署之后,通过部署的IP地址即可访问(PS:这个比较适合公司内部,比如前后端分离开发的是时候)。

2 导出成pdf文档

这个比较简单,不用写代码。利用windows自带的功能即可实现。

点击快捷键Ctrl+p,显示打印页面

使用场景

保存即可。

3 导出成Word文档

  当然,尽管以上两种方式已经很方便了。可是总有些时候,遇到一些难缠的,又不讲道理,偏偏觉得将Swagger文档地址丢给客户会不够正式!死活要一份word文档。

  可是这个时候,如果接口数量上百个,甚至更多,一个一个手动输入word,那将是一笔耗时的工作。但却有什么办法可以解决呢?

  对了,利用Swagge生成的Json文件转换为word文档不就可以了吗?

实现方式
  • 获取Swagger接口文档的Json文件

  • 解析Json文件数据填充到Html的表格中

  • 根据生成的html转work文档

  这就需要在swagger文档代码中做一些扩展。详情可以参考:基于.NetCore3.1系列 —— 使用Swagger导出文档

  导出word的格式如下:

使用场景

基于swagger生成的文档数据,我们就可以按照自己的想法来生成自定义格式的数据了。有兴趣的童鞋可以继续深挖。

参考

免责声明:文章转载自《懒得写文档,swagger文档导出来不香吗》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇VC++API小查SAP MM 公司间退货STO流程后勤部分简述下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

Swagger的应用

一、介绍 一个规范和完整的框架,用于生成、描述、调用和可视化 RESTful 风格的 Web 框架。 二、依赖 <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifac...

C#API接口调试工具

自从去年软件界网站开发推崇前后端分离,我们公司也在进行转行行,从原先的前端架构,后端架构,数据库搭建一肩挑的模式也逐渐转型为前后端分离,大量招收前端开发人员,原来的人员也转型为专职的后端开发,这样的变化就对于后端开发人员的接口调试带来了一定的麻烦,在原来的前后端一起的开发模式下,我们可以利用前端的请求直接后台打断点进行调试,然而进行了前后端分离以后,直接叫...

Spring Boot 入门系列(二十二)使用Swagger2构建 RESTful API文档

前面介绍了如何Spring Boot 快速打造Restful API 接口,也介绍了如何优雅的实现 Api 版本控制,不清楚的可以看我之前的文章:https://www.cnblogs.com/zhangweizhong/category/1657780.html 在实际项目中,Api 接口系统对接过程中,Api 接口文档是非常重要的文档。一般是设计完成之...

golang gin框架使用swagger生成接口文档

前言 一份清晰明了的接口文档能够极大地提高前后端双方的沟通效率和开发效率。 本文将介绍如何使用swagger生成接口文档。 swagger介绍 Swagger本质上是一种用于描述使用JSON表示的RESTful API的接口描述语言。Swagger与一组开源软件工具一起使用,以设计、构建、记录和使用RESTful Web服务。Swagger包括自动文档,代...

【初次使用h0遇到的一些问题】

此篇为萌新级别hzero 食用指南,记述了我学习过程中遇到的问题和心得,所记述不一定正确,仅供参考~ PS:有些图很模糊,不晓得为什么从word或者Ty里拿出来的画质压缩得这么厉害,见谅。    1.版本号问题,当前应避免hzero企业版的 1.6.1和1.6.4版本服务组件(但是也不一定,有的人会出现的问题,别的人不一定会出现。很玄学,可能后续兼容性会加...

Java-IDEA环境搭建swagger

1.项目POM导入包(使用Maven管理的代码) 2.POM文件导入包  1 <dependencyManagement> 2 <dependencies> 3 <dependency> 4 <groupId>io.swagger<...