Spring Boot集成Swagger接口分類與各元素排序問題
在上一篇中我們完成使用JSR-303校驗,以及利用Swagger2得到相關(guān)接口文檔,這節(jié),我們在原先的基礎(chǔ)之上,完成Swagger中關(guān)于對各個元素之間控制前后順序的具體配置方法。
Swagger的接口的分組
首先我們需要對Swagger中的接口也就是以Controller 層作為第一級梯度進行組織的,Controller在我們實際開發(fā)中,與其他具體接口之間是存在一對多的關(guān)系,我們可以將同屬一個模塊的接口定義在一個Controller 中,默認情況之下,我們的Swagger 是以Controller為單位,對接口進行分組管理,在Swagger 中,這個分組的元素被稱為Tag,但是這里的Tag與接口的關(guān)系并不是一對多關(guān)系,它支持更加豐富的多對多的關(guān)系,
默認的分組
首先通過創(chuàng)建一個簡單的例子進,來看一下,我們是如何處理Swagger是如如何根據(jù)Controller來組織Tag與接口關(guān)系的,定義兩個Controller,分別負責(zé)教師管理與學(xué)生管理接口,為了重復(fù)利用代碼,我們就在上一篇的基礎(chǔ)之上進行代碼添加了:
為了簡單明了,我均將下列代碼放在Application類里邊
@RestController @RequestMapping(value = "/teacher") static class TeacherController { @GetMapping("/miaow") public String miaow() { return "miaow"; } } @RestController @RequestMapping(value = "/student") static class StudentController { @ApiOperation("獲取學(xué)生清單") @GetMapping("/list") public String bbb() { return "bbb"; } @ApiOperation("獲取教某個學(xué)生的老師清單") @GetMapping("/his-teachers") public String ccc() { return "ccc"; } @ApiOperation("創(chuàng)建一個學(xué)生") @PostMapping("/aaa") public String aaa() { return "aaa"; } }
此時通過:localhost:8080/swagger-ui.html
訪問得到我們Swagger的組織結(jié)構(gòu)是
在上圖中我們了解到我們定義的控制層,得到的swagger生成的默認結(jié)構(gòu)展示出來了。
application.properties文件
swagger.title=spring-boot-starter-swagger swagger.description=Starter for swagger 2.x swagger.version=1.9.0.RELEASE swagger.license=Apache License, Version 2.0 swagger.licenseUrl=https://www.apache.org/licenses/LICENSE-2.0.html swagger.termsOfServiceUrl=https://github.com/dyc87112/spring-boot-starter-swagger swagger.contact.name=miaow swagger.contact.url=https://luoxiaohei520.github.io swagger.contact.email=miaow@qq.com swagger.base-package=com.didispace swagger.base-path=/** swagger.ui-config.tags-sorter=alpha swagger.ui-config.operations-sorter=alpha
在啟動類添加相關(guān)控制層接口:
@EnableSwagger2Doc @SpringBootApplication public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } @Api(tags = {"1-教師管理","3-教學(xué)管理"}) @RestController @RequestMapping(value = "/teacher") static class TeacherController { @ApiOperation(value = "miaow") @GetMapping("/miaow") public String miaow() { return "miaow"; } } @Api(tags = {"2-學(xué)生管理"}) @RestController @RequestMapping(value = "/student") static class StudentController { @ApiOperation(value = "獲取學(xué)生清單", tags = "3-教學(xué)管理") @GetMapping("/list") public String bbb() { return "bbb"; } @ApiOperation("獲取教某個學(xué)生的老師清單") @GetMapping("/his-teachers") public String ccc() { return "ccc"; } @ApiOperation("創(chuàng)建一個學(xué)生") @PostMapping("/aaa") public String aaa() { return "aaa"; } } }
得到結(jié)果集
自定義默認分組的名稱
@Api(tags = "教師管理") @RestController @RequestMapping(value = "/teacher") static class TeacherController { // ... } @Api(tags = "學(xué)生管理") @RestController @RequestMapping(value = "/student") static class StudentController { // ... }
我們在Api的tags修改成為我們想要的表達文字:
合并Controller分組
在此,我們使用了Tag和Controller 一一對應(yīng)的情況,Swagger中還支持更加靈活的分組!從@Api
注解中,我們?nèi)绻腥タ丛敿毚a的時候,發(fā)現(xiàn)tags
屬性其實是一個數(shù)組類型。
因而,我們可以通過地定義同名的Tag來匯總Controller中的相關(guān)接口,比如我們可以定義一個Tag為“教學(xué)管理“,讓這個分組同時包含教師管理和學(xué)生管理的所有接口,案例如下:
@Api(tags = {"教師管理", "教學(xué)管理"}) @RestController @RequestMapping(value = "/teacher") static class TeacherController { // ... } @Api(tags = {"學(xué)生管理", "教學(xué)管理"}) @RestController @RequestMapping(value = "/student") static class StudentController { // ... }
更新細粒度的接口分組
通過@Api可以實現(xiàn)將Controller中的接口合并到一個Tag
中,但是如果我們希望精確到某個接口的合并,我們應(yīng)該如何做?
@Api(tags = {"教師管理","教學(xué)管理"}) @RestController @RequestMapping(value = "/teacher") static class TeacherController { @ApiOperation(value = "maiow") @GetMapping("/miaow") public String miaow() { return "miaow"; } } @Api(tags = {"學(xué)生管理"}) @RestController @RequestMapping(value = "/student") static class StudentController { @ApiOperation(value = "獲取學(xué)生清單", tags = "教學(xué)管理") @GetMapping("/list") public String bbb() { return "bbb"; } @ApiOperation("獲取教某個學(xué)生的老師清單") @GetMapping("/his-teachers") public String ccc() { return "ccc"; } @ApiOperation("創(chuàng)建一個學(xué)生") @PostMapping("/aaa") public String aaa() { return "aaa"; } }
得到效果圖:
內(nèi)容的順序
在完成了接口的分組后,我們可以進行對接口內(nèi)容的展示順序進行調(diào)整,其中,我們主要涉及三個方面:分組的排序、接口的排序、以及參數(shù)的排序。
分組排序
關(guān)于分組排序,也就是Tag的排序。目前版本的Swagger支持并不太好,通過文檔我們可以找到關(guān)于Tag排序的配置方法。
第一種,適合原生的Swagger用戶,修改:
第二種方式:Swagger Starter用戶,可以通過修改配置的方式:
swagger.ui-config.tags-sorter=alpha
修改上述的配置的源碼:
public enum TagsSorter { ALPHA("alpha"); private final String value; TagsSorter(String value) { this.value = value; } @JsonValue public String getValue() { return value; } public static TagsSorter of(String name) { for (TagsSorter tagsSorter : TagsSorter.values()) { if (tagsSorter.value.equals(name)) { return tagsSorter; } } return null; } }
我們可以發(fā)現(xiàn)Swagger 提供考慮一個選項,就是按照字字母順序進行排序。
@Api(tags = {"1-教師管理","3-教學(xué)管理"}) @RestController @RequestMapping(value = "/teacher") static class TeacherController { // ... } @Api(tags = {"2-學(xué)生管理"}) @RestController @RequestMapping(value = "/student") static class StudentController { @ApiOperation(value = "獲取學(xué)生清單", tags = "3-教學(xué)管理") @GetMapping("/list") public String bbb() { return "bbb"; } // ... }
接口的排序
在完成了分組排序問題(雖然不太優(yōu)雅…)之后,在來看看同一分組內(nèi)各個接口該如何實現(xiàn)排序。同樣的,凡事先查文檔,可以看到Swagger也提供了相應(yīng)的配置,下面也分兩種配置方式介紹:
第一種還是適合原生Swagger用戶的,可以修改:
第二種:Swagger Starter用戶,可以通過修改配置方式:
swagger.ui-config.operations-sorter=alpha
這個配置不像Tag的排序配置沒有可選項。它提供了兩個配置項:alpha和method,分別代表了按字母表排序以及按方法定義順序排序。當我們不配置的時候,改配置默認為alpha。
參數(shù)的排序
完成了接口的排序后,更加細粒度的就是請求參數(shù)的排序了,在默認的情況下,我們的Swagger會對Model的參數(shù)內(nèi)容展示進行按照字母排序,我們的展示的User在Swagger之前是這樣的:
現(xiàn)在,我們希望可以按照Model中定義的成員變量順序來展示,那么需要我們通過@ApiModelProperty
注解的position
參數(shù)來實現(xiàn)位置的設(shè)置。
對應(yīng)的User對象如下:
w未加
@ApiModel(description = "用戶實體") public class User { @ApiModelProperty(value = "用戶編號", position = 1) private Long id; @NotNull @Size(min = 2, max = 5) @ApiModelProperty(value = "用戶姓名", position = 2) private String name; @NotNull @Max(100) @Min(10) @ApiModelProperty(value = "用戶年齡", position = 3) private Integer age; @NotNull @Email @ApiModelProperty(value = "用戶郵箱", position = 4) private String email; public Long getId() { return id; } public void setId(Long id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Integer getAge() { return age; } public void setAge(Integer age) { this.age = age; } public String getEmail() { return email; } public void setEmail(String email) { this.email = email; } public User(Long id, String name, Integer age, String email) { this.id = id; this.name = name; this.age = age; this.email = email; } public User() { } }
加了Position之后的swagger展示:
到此這篇關(guān)于Spring Boot集成Swagger接口分類與各元素排序問題的文章就介紹到這了,更多相關(guān)Spring Boot集成Swagger接口內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
spring boot參數(shù)驗證注解@NotNull、@NotBlank和@NotEmpty區(qū)別解析
使用spring boot參數(shù)驗證是常常會使用@NotNull、@NotBlank和@NotEmpty三個判斷是否不為空的注解,中文都有不能為空的意思,大部分使用者都傻傻分清它們之間到底有什么區(qū)別,今天就讓咱們來一起探索它們之間的不同吧,感興趣的朋友一起看看吧2024-05-05Java利用EasyExcel實現(xiàn)導(dǎo)出導(dǎo)入功能的示例代碼
EasyExcel是一個基于Java的、快速、簡潔、解決大文件內(nèi)存溢出的Excel處理工具。本文廢話不多說,直接上手試試,用代碼試試EasyExcel是否真的那么好用2022-11-11SpringBoot下無節(jié)制和數(shù)據(jù)庫建立連接的問題及解決方法
本文介紹了無節(jié)制建立MySQL連接的危害,包括數(shù)據(jù)庫服務(wù)端資源耗盡、應(yīng)用端性能劣化和監(jiān)控與運維困境,提出了系統(tǒng)性解決方案,包括連接池標準化配置、代碼規(guī)范與防御式編程、全鏈路監(jiān)控體系和架構(gòu)級優(yōu)化,感興趣的朋友一起看看吧2025-03-03Java實現(xiàn)微信登錄并獲取用戶信息功能(開發(fā)流程)
這篇文章主要介紹了Java實現(xiàn)微信登錄并獲取用戶信息功能(開發(fā)流程),本文通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下2024-07-07從0到1構(gòu)建springboot web應(yīng)用鏡像并使用容器部署的過程
這篇文章主要介紹了從0到1構(gòu)建springboot web應(yīng)用鏡像并使用容器部署,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-03-03