手动编写Swagger文档与部署指南
Swagger介绍
在Web开发中,后端开发者在完成接口开发后,需要给前端相应的接口使用说明,所以一般会写一份API文档。一般来说,有两种方式提供API接口文档,一种是利用插件在代码中自动生成,另一种是手工编写API文档。
Swagger就是为API文档设计而生的,其中包含一整套相关工具,既支持利用插件在代码中进行注解从而自动生成文档,也支持手工编写文档。两种方式各有优缺点:
- 自动生成:省时,方便。只需在编写代码的时候添加一点注解就可以帮你自动完成文档的生成和部署。但是缺点也很明显,对于比较复杂的接口,或者在参数中使用自定义参数解析器的接口,它的支持就不太完美,换句话说,生成的文档很“死板”,里面可能有很多与预期不太符合的东西。(期待相关插件功能越来越完善,我相信有一天会完全取代手工编写的方式)。
- 手工编写:灵活性高,能够完美的表达自己的想法。缺点就是需要额外的编写,维护和管理。
接下来我对两种方式分别做一下介绍。
自动生成
自动生成的方式还是比较容易的,对于不同的语言,有不同的插件以供使用。
- 如果你的后台用node编写,可以使用koa-swagger-decorator来生成API文档。
- 如果你的后台采用spring-boot方案,可以用springfox开发的一套插件来生成Swagger文档。具体可以参考这个教程。
- 对于其他技术路线,读者可以自行Google搜索是否有相关插件以供使用。
接下来我主要讲解一下手工编写的方式。
手工编写
后台开发者在完成接口开发后,需要进行如下流程:
- 在Swagger Editor中编写swagger.yaml文件(具体语法见官方教程,比较简单).
- 在Swagger Editor中将yaml文件导出为json文件。
- 利用Swagger UI渲染json文件,并且部署在服务器上。
其中前两点比较容易,有比较好的参考教程,一步步走下来就行。而利用Swagger UI渲染并部署,稍微麻烦一些,下面我将自己的做法给大家分享一下。
首先,在开始之前,可以看看我们项目组的一个示例。这个 Swagger 是我部署上去的,可以比较方便的查看,并且利用Try it out功能可以进行实时的测试,这也是利用Swagger编写API文档很大的一个好处。
接下来正式讲解如何使用Swagger UI渲染json文件,并且部署在服务器上。
Swagger-UI的官方仓库里明确说明了:他们在npm仓库里上传了两个npm模块,分别是swagger-ui
和 swagger-ui-dist
. 这两种方式都需要npm的支持,也就是说我们需要在服务器上运行一个node程序来专门为swagger服务,特别是当我们的服务器端不是用node.js写的时候,需要额外花费较大的精力和时间。那么我们有没有办法 不使用任何node.js库,直接将Swagger UI部署在云端呢? 答案当然是有的,我们只需要充分利用官方仓库中的/dist
文件夹即可。具体步骤如下:
- 首先我们进入Swagger-UI的官方仓库,将其克隆至本地.
- 进入仓库中的
/dist
文件夹,用浏览器打开index.html
文件,这个时候,应该可以看到官方的Swagger PetStore
API实例文件已经打开并且成功渲染。 - 将我们撰写的json文件上传到云端服务器上。确保能够远程访问。(例如您可以尝试我上传的http://121.42.175.137/swagger.json, 能够到达这个效果就算成功)
- 用编辑器打开2中的
index.html
文件,将onload function
中的url:"https://petstore.swagger.io/v2/swagger.json"
改为自己服务器上json文件的URL。 - 再次用浏览器打开
index.html
,成功访问到我们自己的API文档。 - 将
dist
文件夹整个上传到云端服务器,即全部完成。
这个方法是我自己摸索出来的,主要是利用了dist
文件夹已经拥有渲染json文件的全部能力,这里包含了所有的html, css, js,于是我们可以直接拿来用了~当然这样也有一点缺陷,就是更新会不及时。官网上偶尔会更新dist文件夹,而我们的dist文件夹是不会自己更新的,但是也没有太大关系。
本机渲染
以上方法基于拥有远程服务器的前提。如果您想用此方法在本机上渲染json,同样也是有方法的,只需要利用http-server
或其他的本地服务器程序,将json文件挂到本机某一端口(例如8080),然后将index.html
中的url改为localhost:8080/xxx.json
即可。
手动编写Swagger文档与部署指南的更多相关文章
- 运用swagger编写api文档
一.什么是swagger 随着互联网技术的发展,前后端技术在各自的道路上越走越远,他们之间的唯一联系变成了api接口,api接口文档编程了前后端人员的纽带,而swagger就是书写api文档的一款框架 ...
- 懒得写文档,swagger文档导出来不香吗
导航 前言 离线文档 1 保存为html 2 导出成pdf文档 3 导出成Word文档 参考 前言 早前笔者曾经写过一篇文章<研发团队,请管好你的API文档>.团队协作中,开发文档的重 ...
- 向架构师进军--->如何编写软件架构文档
如果你对项目管理.系统架构有兴趣,请加微信订阅号"softjg",加入这个PM.架构师的大家庭 问:为什么要编写软件架构文档,它的好处是什么? 答: 有文档的架构有助于不同利益相关 ...
- 向架构师进军--->怎样编写软件架构文档
假设你对项目管理.系统架构有兴趣,请加微信订阅号"softjg",增加这个PM.架构师的大家庭 问:为什么要编写软件架构文档,它的优点是什么? 答: 有文档的架构有助于不同利益相关 ...
- Swagger文档转Word 文档
GitHub 地址:https://github.com/JMCuixy/SwaggerToWord/tree/developer 原创作品,转载请注明出处:http://www.cnblogs.co ...
- 使用 Swagger 文档化和定义 RESTful API
大部分 Web 应用程序都支持 RESTful API,但不同于 SOAP API——REST API 依赖于 HTTP 方法,缺少与 Web 服务描述语言(Web Services Descript ...
- Swagger文档转Word
Swagger文档转Word 文档 GitHub 地址:https://github.com/JMCuixy/SwaggerToWord/tree/developer 原创作品,转载请注明出处:h ...
- Spring Boot:整合Swagger文档
综合概述 spring-boot作为当前最为流行的Java web开发脚手架,越来越多的开发者选择用其来构建企业级的RESTFul API接口.这些接口不但会服务于传统的web端(b/s),也会服务于 ...
- 【Swagger2】解决swagger文档地址请求404的问题
一.出现的问题背景 某个项目,本地启动后,访问swagger文档地址可以访问到, http://localhost:8203/doc.html.但是部署到开发环境就访问不到,报404资源找不到的问题 ...
- 使用 Laravel-Swagger 编写接口文档(php)
使用 Laravel-Swagger 编写接口文档 Table of Contents Swagger 文档管理 官方网站:https://swagger.io/ 快速编写你的 RESTFUL API ...
随机推荐
- IIR数字滤波器的设计
IIR数字滤波器的设计 Mrakdown常见数学符号 Markdown基础语法 冲激响应不变法 冲激响应不变法:就是用其单位冲激响应序列模仿模拟滤波器的单位冲激响应的抽样值 设计的具体步骤及方法 ...
- CH573 CH582 CH579蓝牙主机(Central)例程讲解一(主机工作流程)
蓝牙主机,顾名思义,就是一个蓝牙主设备,与从机建立连接进行通信,可以接收从机通知,也可以给从机发送信息,可将Central例程和Peripheral例程结合使用. 蓝牙主机例程的工作流程大致如下: 一 ...
- STM32使用DMA接收不定长数据
开启串口,是能串口全局中断 配置DMA并勾选Memory选项 继续配置工程并且生成代码 添加一些串口通讯使用的全局变量 #define BUFFER_SIZE 128 uint8_t Tx_Buf[5 ...
- js 小数和百分数的转换
百分数转化为小数 function toPoint(percent){ var str=percent.replace("%",""); str= str/10 ...
- 【MSSQL】AlwaysOn集群增加发布订阅
在现有AlwaysOn集群增加发布订阅节点 配置 前提 节点1.节点2在AlwaysOn集群,节点3作为集群外节点使用订阅复制集群数据同步 发布对象必须要有主键 步骤 登录节点3配置分发distrib ...
- [BUUCTF]HCTF 2018WarmUp1 write up
ctrl+U查看源代码, 如下: 访问提示中的source.php文件 发现显示了源码,且存在另一个PHP文件hint.php(提示.php),先查看文件内是否有信息 用file来传参,并且要绕过wh ...
- pip第三方库安装失败原因及解决办法
pip安装三方库失败原因及解决方法 提示:WARNING: You are using pip version 20.2.3, however version 20.2.4 is available. ...
- 虚拟环境 venv的使用--(venv 一)
一.引言最近在学习<Flask Web Development 2nd Edition>的时候,作者开篇就介绍如何使用 venv 来管理 Python 环境 .自我觉得作者讲的非常好,想要 ...
- Javaweb知识复习--MyBatis+Mapper代理开发
一种持久层框架,主要用于简化JDBC MyBatis应用步骤 1.在数据库里面创建一个表 2.创建模块,导入坐标 就是新建一个Maven项目,在pom.xml里面导入mybatis相应导包依赖代码: ...
- progress监视linux命令进程
progress监视linux命令进程 可以查看哪些命令进程 cp mv tar dd gzip cat grep 如何在ubuntu安装 sudo apt install progress 使用方法 ...