SpringBoot使用Swagger生成多模塊的API文檔
在大型項(xiàng)目中,通常會(huì)采用多模塊的架構(gòu)設(shè)計(jì),以提高代碼的可維護(hù)性和可擴(kuò)展性。使用 Swagger 為多模塊項(xiàng)目生成 API 文檔時(shí),需要進(jìn)行一些特殊的配置。以下以 Spring Boot 多模塊項(xiàng)目為例,詳細(xì)介紹如何使用 Swagger 生成多模塊的 API 文檔。
項(xiàng)目結(jié)構(gòu)
假設(shè)我們有一個(gè)包含多個(gè)模塊的 Spring Boot 項(xiàng)目,結(jié)構(gòu)如下:
multi-module-project
├── common-module
│ └── src
│ └── main
│ └── java
│ └── com
│ └── example
│ └── common
│ └── ...
├── module-a
│ └── src
│ └── main
│ └── java
│ └── com
│ └── example
│ └── modulea
│ └── ...
├── module-b
│ └── src
│ └── main
│ └── java
│ └── com
│ └── example
│ └── moduleb
│ └── ...
└── api-gateway
└── src
└── main
└── java
└── com
└── example
└── apigateway
└── ...
步驟 1:添加依賴
在每個(gè)需要生成 API 文檔的模塊的 pom.xml 中添加 Swagger 相關(guān)依賴:
<dependencies>
<!-- Swagger API 注解 -->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>2.9.2</version>
</dependency>
<!-- Swagger UI -->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
<version>2.9.2</version>
</dependency>
</dependencies>
步驟 2:配置 Swagger
在每個(gè)模塊中創(chuàng)建 Swagger 配置類,例如在 module-a 中:
package com.example.modulea.config;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;
@Configuration
@EnableSwagger2
public class SwaggerConfig {
@Bean
public Docket api() {
return new Docket(DocumentationType.SWAGGER_2)
.select()
.apis(RequestHandlerSelectors.basePackage("com.example.modulea.controller"))
.paths(PathSelectors.any())
.build();
}
}在 module-b 中也進(jìn)行類似的配置,只需將 basePackage 替換為 com.example.moduleb.controller。
步驟 3:統(tǒng)一 API 網(wǎng)關(guān)配置(可選)
如果項(xiàng)目中有 API 網(wǎng)關(guān)模塊(如 api-gateway),可以在該模塊中配置 Swagger,將各個(gè)模塊的 API 文檔聚合在一起。
package com.example.apigateway.config;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;
@Configuration
@EnableSwagger2
public class SwaggerConfig {
@Bean
public Docket api() {
return new Docket(DocumentationType.SWAGGER_2)
.select()
.apis(RequestHandlerSelectors.basePackage("com.example"))
.paths(PathSelectors.any())
.build();
}
}這里的 basePackage 設(shè)置為包含所有模塊控制器的根包,這樣 Swagger 會(huì)掃描該包下所有模塊的控制器,并生成統(tǒng)一的 API 文檔。
步驟 4:添加 API 注解
在每個(gè)模塊的控制器類和方法上添加 Swagger 注解,以描述 API 信息。例如在 module-a 的控制器中:
package com.example.modulea.controller;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
@RequestMapping("/module-a")
@Api(value = "Module A API", description = "這是 Module A 的 API 文檔")
public class ModuleAController {
@GetMapping("/hello")
@ApiOperation(value = "獲取 Module A 的問候語(yǔ)", notes = "返回一個(gè)簡(jiǎn)單的問候語(yǔ)")
public String hello() {
return "Hello from Module A!";
}
}在 module-b 的控制器中也進(jìn)行類似的操作。
步驟 5:查看 API 文檔
啟動(dòng)各個(gè)模塊的 Spring Boot 應(yīng)用程序,訪問相應(yīng)模塊的 Swagger UI 地址(如 http://localhost:8080/module-a/swagger-ui.html 或 http://localhost:8080/api-gateway/swagger-ui.html,端口號(hào)和路徑根據(jù)實(shí)際情況修改),即可查看各個(gè)模塊或統(tǒng)一的 API 文檔。
注意事項(xiàng)
確保每個(gè)模塊的 Swagger 配置類中的 basePackage 配置正確,以確保能夠掃描到相應(yīng)模塊的控制器。
如果使用 API 網(wǎng)關(guān)進(jìn)行文檔聚合,要注意網(wǎng)關(guān)的路由配置,確保能夠正確訪問各個(gè)模塊的 API。
可以根據(jù)需要對(duì) Swagger 的配置進(jìn)行定制,如設(shè)置文檔標(biāo)題、描述、版本等信息。
通過(guò)以上步驟,你可以為 Spring Boot 多模塊項(xiàng)目使用 Swagger 生成清晰、統(tǒng)一的 API 文檔,方便開發(fā)和測(cè)試人員查看和使用。
到此這篇關(guān)于SpringBoot使用Swagger生成多模塊的API文檔的文章就介紹到這了,更多相關(guān)SpringBoot Swagger生成API文檔內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
利用Java讀取Word表格中文本和圖片的方法實(shí)例
這篇文章主要給大家介紹了關(guān)于如何利用Java讀取Word表格中文本和圖片的相關(guān)資料,主要利用的是free spire.doc.jar 包,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下2021-07-07
java+MongoDB實(shí)現(xiàn)存圖片、下載圖片的方法示例
這篇文章主要介紹了java+MongoDB實(shí)現(xiàn)存圖片、下載圖片的方法,結(jié)合實(shí)例形式詳細(xì)分析了java結(jié)合MongoDB實(shí)現(xiàn)圖片的存儲(chǔ)與下載相關(guān)操作技巧,需要的朋友可以參考下2019-09-09
SpringBoot實(shí)現(xiàn)動(dòng)態(tài)控制定時(shí)任務(wù)支持多參數(shù)功能
這篇文章主要介紹了SpringBoot實(shí)現(xiàn)動(dòng)態(tài)控制定時(shí)任務(wù)-支持多參數(shù)功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-05-05
利用MultipartFile實(shí)現(xiàn)文件上傳功能
這篇文章主要為大家詳細(xì)介紹了利用MultipartFile實(shí)現(xiàn)文件上傳功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-11-11
通過(guò)RedisTemplate連接多個(gè)Redis過(guò)程解析
這篇文章主要介紹了通過(guò)RedisTemplate連接多個(gè)Redis過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08
java finally塊執(zhí)行時(shí)機(jī)全面分析
下面小編就為大家?guī)?lái)一篇java finally塊執(zhí)行時(shí)機(jī)全面分析。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-08-08
Spring Cloud學(xué)習(xí)教程之DiscoveryClient的深入探究
這篇文章主要給大家介紹了關(guān)于Spring Cloud學(xué)習(xí)教程之DiscoveryClient的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2018-04-04
SpringBoot監(jiān)控模塊Actuator的用法詳解
Spring?Boot?Actuator?是?Spring?Boot?自帶的一個(gè)功能模塊,提供了一組已經(jīng)開箱即用的生產(chǎn)環(huán)境下常用的特性和服務(wù),比如應(yīng)用程序的健康檢查、信息暴露、度量收集、日志記錄等,本文將給大家詳細(xì)SpringBoot監(jiān)控模塊Actuator的用法2023-06-06

