微服务系统设计(04)——接口文档管理设计

article/2025/10/7 18:58:02

摘要

整个系统是多个应用一起构建,由于服务不会单独存在,服务开发团队必然与其他服务团队进行服务调用,暴露出对外接口势在必行。早期做开发的时候,大家习惯于以 word 或 excel 的形式,但弊端显而易见,一旦接口发生变动,文档需要同步更新,遗憾的是很多接口已经更新,但文档都没有跟上,相信你也有过痛苦的经历。本文带领你认识几款接口文档管理工具,并实现本案例实践中用到的在线接口文档管理。我们迫切需要一个接口文档工具,能实时与系统接口保持同步,无须额外付出成本(资金成本、时间成本)最好。这里介绍几个开源的 API 工具,可以选择使用。

一、RAP2

官方地址:RAP接口管理平台,早期称为 RAP ,阿里妈妈 MUX 团队出品,后面项目停止维护,转移至 RAP2 项目。可以在线使用,也可以本地部署使用,本地部署有详细的步骤介绍,从部署手册来看,产品还是比较重的,环境依赖也比较多。部署后,同样存在要花时间保持与代码同步的问题,针对提供比较稳定接口的项目而言,是个不错的选择。

二、APIDOC

官方地址:apiDoc - Inline Documentation for RESTful web APIs,通过代码中的相当格式的注释来生成 API 接口文档,依赖 Node.js 环境。使用比较简单,弊端:接口发生变动时,需要花时间来同步文档。针对比较稳定的接口系统而言,可以做个备选。

三、Spring REST Docs

Spring 全家桶中很多 API 文档,都是基于此组件生成,据官方提供的使用方法需要编写相应的代码片断,还有相应的语法规范,再通过项目构建的方式生成离线文档。操作起来比较繁琐,这里不推荐使用。生成的文档形如下面截图中所示:

四、Swagger

官网地址:https://swagger.io , 是一款 RESTFU L 接口的文档在线自动生成+功能测试功能软件,是一个规范和完整的框架,标准的,语言无关,用于生成、描述、调用和可视化 RESTful 风格的 Web 服务。总体目标是使客户端和文件系统作为服务器以同样的速度来更新。文件的方法,参数和模型紧密集成到服务器端的代码,允许 API 来始终保持同步。Swagger 让部署管理和使用功能强大的 API 从未如此简单。本实战案例中采用 Swagger 来进行的 API 的管理。

五、Spring Boot 整合 Swagger2

5.1 引入依赖

加入 Swagger 相关的 jar 依赖,由于各个子模块都有用到,这里将 Swagger 在根 pom.xml 中进行统一的版本管理

<properties><swagger.version>2.8.0</swagger.version>
</properties>
<!--swagger2 -->
<dependency><groupId>io.springfox</groupId><artifactId>springfox-swagger2</artifactId><version>${swagger.version}</version>
</dependency>
<dependency><groupId>io.springfox</groupId><artifactId>springfox-swagger-ui</artifactId><version>${swagger.version}</version>
</dependency>

子模块中无须配置 version,直接引入即可,如果需要变更 version,直接在根 pom.xml 中修改,所有依赖子模块的版本也会一同发生变更。

<!--swagger2 -->
<dependency><groupId>io.springfox</groupId><artifactId>springfox-swagger2</artifactId>
</dependency>
<dependency><groupId>io.springfox</groupId><artifactId>springfox-swagger-ui</artifactId>
</dependency>

5.2 Swagger2 配置

建立 config 包,新增 Swagger 配置类。通过@EnableSwagger2注解启用 Swagger2 ,然后配置一个 Docket Bean ,配置映射路径和要扫描的接口的位置,在 apiInfo 中,主要配置一下 Swagger2 文档网站的信息,例如网站的 title ,网站的描述,联系人的信息,使用的协议、接口的版本等等。

@EnableSwagger2
@Configuration
public class Swagger2Config {@Beanpublic Docket createRestApi() {return new Docket(DocumentationType.SWAGGER_2).apiInfo(apiInfo()).select().apis(RequestHandlerSelectors.any()).paths(PathSelectors.any()).build();}private ApiInfo apiInfo() {return new ApiInfoBuilder().title("Member 会员模块接口层(基于 SpringBoot2+Swagger2).").contact(new Contact("growithus", "https://backkoms.github.io/", "andy.deqiang@gmail.com")).version("1.0").description("").build();}
}

由于采用的是较高版本,相应的 Controller 类中无须再编写 Swagger 相应的代码注解,代码侵入性进一步降低。旧版本相关的注解,如 @Api、@ApiOperation、@ApiImplicitParams、@ApiImplicitParam,@ApiModel等,如果是旧版本,必须要在相关代码中增加以上相应的注解,对代码有一定侵入性。经过以上两个步骤,Swagger2 就算配置成功了,非常简捷。启动项目,输入 http://localhost:10060/swagger-ui.html,能够看到如下 UI,说明已经配置成功了。

5.3 API 验证测试

编写测试类,启动项目

@RestController
@RequestMapping("test")
public class APITestController {@PostMapping("/hello")//只支持 POST 请求//@RequestMapping(name = "hello", method = { RequestMethod.POST })//同样只支持 POST 请求public String hello(String name) {return "hello " + name;}}

Request 方法有 8 种请求类型:POST \ GET \ OPTIONS \ HEAD \ PUT \ DELETE \ TRACE \ PATCH,为确保不必要的请求造成的潜在威胁,案例建议中直接采用 POST 方式一种,禁用其它请求方式。 @PostMapping("/hello") 功能等同于@RequestMapping(name= "hello", method = { RequestMethod.POST })

直接使用 Shell 脚本进行请求测试:

appledeMacBook-Air:~ apple$ curl -X POST "http://localhost:10060/test?name=world" hello world.可以看到正常输出结果,再测试一下其它请求方式能否正常请求数据:appledeMacBook-Air:~ apple$ curl -X GET "http://localhost:10060/test?name=world" {"timestamp":"2020-02-01T12:59:09.508+0000","status":405,"error":"Method Not Allowed","message":"Request method 'GET' not supported","path":"/test"}

未使用 Swagger 时,可以采用 Postman 测试工具进行接口调试。


现在已经集成Swagger 功能,打开http://localhost:10060/swagger-ui.html,找到 api-test-controller 下对应的方法,点击" try it out ",输入参数,执行" Execute "功能。查看正常输出结果:
 

使用 Swagger 即可在直接在线感知接口变更,还能在 UI 上直接进行接口测试,不再依赖第三方组件。

5.4 生产环境屏蔽

使用 Swagger 大大提高接口的开发测试效率,如果不加以限制,暴露在生产环境中,那就是一个潜在的安全风险,所以在开发、测试环节正常使用,但要在生产环境中屏蔽 Swagger 的功能。上一篇中提及到多环境配置的问题,这里可以利用它来做文章。

实现方式很简单,在 Swagger 配置类增加注解 @Profile({ "dev", "test" }) ,标记只有在 dev 或 test 环境下才能正常使用 swagger 的接口调试功能,在生产环境下这个类是不会加载的,也就达到了生产环境下屏蔽的目标。启动后测试发现,swagger-ui.html 页面已不能正常加载接口进行测试。

@EnableSwagger2
@Configuration
@Profile({ "dev", "test" })
public class Swagger2Config {
}

注意:任何@Componen t或@Configuration注解的类都可以使用@Profile注解。

5.5 增加 token 统一参数

不少内部服务是需要用户登陆后才能正常使用的,比如用户签到领取积分,必须登陆后才正常使用,如果在每个接口中增加 token 参数,重复度太高,设计也不够优雅,一般情况下将 token 放到请求头中较为合适, Swagger 页面中如何显性增加输入 token 的位置就变成了我们的目标。

在 Swagger 配置类修改配置,完成后如下:

@EnableSwagger2
@Configuration
@Profile({ "dev", "test" })
public class Swagger2Config {@Beanpublic Docket createRestApi() {ParameterBuilder parameterBuilder = new ParameterBuilder();List<Parameter> parameters = new ArrayList<>();parameterBuilder.modelRef(new ModelRef("String")).name("token").parameterType("header").description("token").defaultValue("").//考虑到有些请求是不需要 token 的,此处不能置必填required(false).build();parameters.add(parameterBuilder.build());return new Docket(DocumentationType.SWAGGER_2).apiInfo(apiInfo()).select().apis(RequestHandlerSelectors.any()).paths(PathSelectors.any()).build().globalOperationParameters(parameters).securitySchemes(getSecuritySchemes());}private ApiInfo apiInfo() {return new ApiInfoBuilder().title("Member 会员模块接口层(基于 SpringBoot2+Swagger2).").contact(new Contact("growithus", "https://backkoms.github.io/", "andy.deqiang@gmail.com")).version("1.0").description("").build();}private List<ApiKey> getSecuritySchemes() {List<ApiKey> keys = new ArrayList<>();ApiKey key  = new ApiKey("token", "token", "header");keys.add(key);return keys;}
}

启动项目后,打开 swagger-ui.html 页面,会发现多出一个 Authorize 的按钮,打开后输入有效 token 就实现登陆,其它接口直接使用即可,无须多次再输入 token (此时并未实现 token 验证,后续可通过 AOP 编程来验证 token 的有效性)。

到此,Swagger 已经可以正常应用在项目中,后续直接 Copy 本示例的配置即可复用。

每个子服务模块都会对外暴露接口,如果调用服务很多,将不得不面对接口页面来回切换的繁琐,有没有什么办法简化一下呢?

博文参考


http://chatgpt.dhexx.cn/article/C654yi6r.shtml

相关文章

系统设计与实现

6.搭建大规模可扩展系统&#xff08;一&#xff09;_哔哩哔哩_bilibili 短网址系统设计_哔哩哔哩_bilibili 一.短url设计 后端面试之系统设计-短网址&#xff08;Short URL&#xff09;服务怎么设计&#xff1f;_码农在新加坡的博客-CSDN博客_短网址服务 系统设计(五) Desi…

文件系统的设计与实现(操作系统课程设计)

转发请注明&#xff1a;http://blog.csdn.net/tianqingdezhuanlan/article/details/51344739 源码下载地址&#xff1a;http://download.csdn.net/download/u013255737/9513460 一、设计目的、意义 1.通过模拟文件系统的实现&#xff0c;深入理解操作系统中文件系统的理论知识,…

消息通知系统设计文档

一、功能概述 1.不同的系统的消息&#xff0c;管理后台&#xff0c;小程序&#xff08;B/C)&#xff0c;微信公众号&#xff0c;短信&#xff0c;邮件等 2.不同业务的消息&#xff0c;充值&#xff0c;提现到账&#xff0c;系统更新&#xff0c;公告等 3.消息的明细&#xff0c…

图书管理系统设计文档汇总

1.编写目的&#xff1a; 现阶段大学生对于课外的书籍阅读越来越看重&#xff0c;有更多的意愿去了解本专业之外的内容以及拓展本专业外的技能。建立一个图书管理借阅数据库方便大家的学习。 2.数据库命名规则&#xff1a; 利用“_”作为连接符&#xff0c;将名词连接在一起&…

学生信息管理系统详细设计文档

第一章引言 1.1编写目的 本文档给出了“学生信息管理系统”的详细设计。针对高校学生群体数量较大&#xff0c;为方便高校学生信息管理&#xff0c;我们设计了一个较为高效的学生信息管理系统。编写该文档目的&#xff1a;便于用户&#xff0c;开发人员之间进行理解和交流&am…

[计算机通信网络]以太网的帧格式详解

目录 一、前言 二、以太网的帧格式 Preamble&#xff08;前导码&#xff09;&#xff1a; SFD&#xff08;帧开始定界符&#xff09;&#xff1a; Destination Address&#xff0c;Source Address&#xff1a; Type/Len&#xff08;类型/长度&#xff09;&#xff1a; Da…

单片机与计算机之间通讯 程序,如何实现计算机与单片机之间的通信

描述 本文是关于计算机与单片机的通信实验的应用。主要包括实验原理阐述、硬件电路图、源程序等 目录&#xff1a; 1、单片机串口通信的应用 2、PC控制单片机IO口输出 3、单片机控制实训指导及综合应用实例 4、单片机给计算机发送数据&#xff1a; &#xff3b;实验任务&#x…

853-两台计算机之间是如何通信的?

1. 五层协议参考模型 所谓通信协议就是通信双方都必须要遵守的通信规则。如果没有网络通信协议&#xff0c;计算机的数据将无法发送到网络上&#xff0c;更无法到达对方计算机&#xff0c;即使能够到达&#xff0c;对方也未必能读懂。有了通信协议&#xff0c;网络通信才能够发…

设备VMnet0 上的网桥当前未运行。此虚拟机无法与主机或网格中的其他计算机通信

关闭虚拟机后&#xff08;下面要恢复默认设置前需要关机&#xff09;&#xff0c;打开 编辑菜单》虚拟网络编辑器 打开后恢复默认设置或修改VMnet0为“自动桥接”&#xff0c;直到与步骤2结果一样&#xff0c;点确定关闭设置窗口。 开机前先“虚拟机设置》网格适配器》设置状态…

网络工程属于计算机还是通信,通信工程属于计算机大类吗 哪个大类

通信工程专业属于电子信息类,属于计算机(大类)类。通信工程不算是计算机的相关专业&#xff0c;通信工程(也作电信工程&#xff0c;旧称远距离通信工程、弱电工程)是电子工程的一个重要分支&#xff0c;电子信息类子专业&#xff0c;同时也是其中一个基础学科。 通信工程相近专…

计算机网络通信技术的重要性,分析计算机网络通信技术的特点及应用效果

摘要&#xff1a;随着计算机网络技术的快速发展&#xff0c;在很多领域中都可以实现该技术的合理利用。本文针对计算机网络通信技术的特点进行分析&#xff0c;并且结合实际情况&#xff0c;提出该技术的未来发展前景&#xff0c;为计算机网络通信技术的应用效果提供有效保障。…

2018计算机通信网络,2018年1-12月我国计算机、通信和其他电子设备制造业企业数量共计16656个...

中国报告网提示&#xff1a; 参考观研天下发布《2019年中国电子设备市场分析报告-市场深度分析与未来商机预测》 &nb 2018年1-12月我国计算机、通信和其他电子设备制造业企业数量共计16656个&#xff0c;累计同比增长5.69%&#xff1b;其中&#xff0c;1-12月我国计算机、通…

【计算机通信网络复习】第1章-计算机网络概论

计算机网络概论 1.1 计算机网络的形成与发展&#xff08;了解&#xff09; 1.1.1 计算机网络发展阶段的划分 第一阶段&#xff1a;计算机网络的形成与发展 &#xff08;1&#xff09;时间&#xff1a;20世纪50年代。 &#xff08;2&#xff09;特点&#xff1a;1. 数据通信技…

【计算机网络】网络通信基础

文章目录 网络通信基础网络通信基本概念信息的传递过程数据通信网络基本概念网络设备交换机&#xff08;Switch&#xff09;路由器&#xff08;Router&#xff09;防火墙&#xff08;Firewall&#xff09;无线设备 局域网、城域网、广域网网络拓扑 网络通信基础 计算机网络 计…

计算机网络数据通信论文,浅谈计算机网络与数据通信的发展

浅谈计算机网络与数据通信的发展 随着计算机网络技术与多媒体通信技术的广泛运用,数据通信是行业发展的必然趋势,下面是小编搜集整理的一篇探究计算机网络与数据通信发展的论文范文,欢迎阅读查看。 摘 要:数据通信是通信技术和计算机技术相结合而产生的一种新的通信方式,未…

通信网与计算机网络的区别,计算机网络和计算机通信网络之间的本质区别是什么?...

原标题&#xff1a;计算机网络和计算机通信网络之间的本质区别是什么&#xff1f; 1、用途不同 计算机网络在网络操作系统&#xff0c;网络管理软件及网络通信协议的管理和协调下&#xff0c;实现资源共享和信息传递。计算机通信在计算机与计算机之间或计算机与终端设备之间进行…

计算机通信与网络(一)

一、计算机通信与网络基础 1.计算机通信与网络的发展 四个阶段&#xff1a; 其中第二阶段产生了分组交换网&#xff0c;分组交换网是以网络为中心&#xff0c;主机都处在网络的外围。 第三阶段形成了基于TCP/IP的因特网。TCP&#xff08;Transmission Control Protocol&…

我国计算机通信技术现状及未来的发展趋势,概述计算机通信技术的发展趋势

概述计算机通信技术的发展趋势 随着世界信息化科技的快速发展,我国的计算机网络通信需求随着人们生活的丰富多彩而不断扩增,以下是小编搜集整理的一篇探究计算机网络通信新技术的论文范文,供大家阅读参考。 摘 要:随着我国科技信息的快速发展,计算机网络通信方面也随着其需…

pta 计算机通信(并查集)

有n台计算机&#xff0c;编号为1到n。设定如果计算机a和计算机b可以通信&#xff0c;则计算机b和计算机a亦可以通信&#xff1b;如果计算机a和计算机b可以相互通信&#xff0c;计算机b和计算机c可以相互通信&#xff0c;则计算机a和计算机c亦可以相互通信。现给定某些计算机的可…

计算机网络与无线通信系统学习1:计算机通信网概述

一、计算机通信网 计算机通信网通常也简称为计算机网络。它是计算机的运算和处理功能同通信系统的信息传输功能相结合的产物。这两种功能的结合所产生的效果远远超过了它们各自发展所能达到的目标。今天&#xff0c;不管是哪个国家的、从事哪个职业的人&#xff0c;从小孩到老…