欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Spring Boot集成Swagger接口分類與各元素排序問題

 更新時間:2023年10月27日 10:08:37   作者:Miaow.Y.Hu  
這篇文章主要介紹了Spring Boot集成Swagger接口分類與各元素排序問題,首先我們需要對Swagger中的接口也就是以Controller 層作為第一級梯度進行組織的,Controller在我們實際開發(fā)中,與其他具體接口之間是存在一對多的關(guān)系,本文給大家介紹的非常詳細,需要的朋友參考下吧

在上一篇中我們完成使用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ū)別解析

    使用spring boot參數(shù)驗證是常常會使用@NotNull、@NotBlank和@NotEmpty三個判斷是否不為空的注解,中文都有不能為空的意思,大部分使用者都傻傻分清它們之間到底有什么區(qū)別,今天就讓咱們來一起探索它們之間的不同吧,感興趣的朋友一起看看吧
    2024-05-05
  • Java利用EasyExcel實現(xiàn)導(dǎo)出導(dǎo)入功能的示例代碼

    Java利用EasyExcel實現(xiàn)導(dǎo)出導(dǎo)入功能的示例代碼

    EasyExcel是一個基于Java的、快速、簡潔、解決大文件內(nèi)存溢出的Excel處理工具。本文廢話不多說,直接上手試試,用代碼試試EasyExcel是否真的那么好用
    2022-11-11
  • 使用Springboot注解形式進行模糊查詢

    使用Springboot注解形式進行模糊查詢

    這篇文章主要介紹了使用Springboot注解形式進行模糊查詢的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • SpringBoot下無節(jié)制和數(shù)據(jù)庫建立連接的問題及解決方法

    SpringBoot下無節(jié)制和數(shù)據(jù)庫建立連接的問題及解決方法

    本文介紹了無節(jié)制建立MySQL連接的危害,包括數(shù)據(jù)庫服務(wù)端資源耗盡、應(yīng)用端性能劣化和監(jiān)控與運維困境,提出了系統(tǒng)性解決方案,包括連接池標準化配置、代碼規(guī)范與防御式編程、全鏈路監(jiān)控體系和架構(gòu)級優(yōu)化,感興趣的朋友一起看看吧
    2025-03-03
  • java中thread線程start和run的區(qū)別

    java中thread線程start和run的區(qū)別

    這篇文章主要介紹了java中thread線程start和run的區(qū)別,run()是Runnable接口中定義的一個方法,是為了讓客戶程序員在這個方法里寫自己的功能代碼的。直接調(diào)用和普通的類調(diào)用自己的成員方法是沒有任何區(qū)別的
    2014-03-03
  • Java實現(xiàn)微信登錄并獲取用戶信息功能(開發(fā)流程)

    Java實現(xiàn)微信登錄并獲取用戶信息功能(開發(fā)流程)

    這篇文章主要介紹了Java實現(xiàn)微信登錄并獲取用戶信息功能(開發(fā)流程),本文通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2024-07-07
  • Java超詳細講解繼承和多態(tài)的使用

    Java超詳細講解繼承和多態(tài)的使用

    繼承就是可以直接使用前輩的屬性和方法。自然界如果沒有繼承,那一切都是處于混沌狀態(tài)。多態(tài)是同一個行為具有多個不同表現(xiàn)形式或形態(tài)的能力。多態(tài)就是同一個接口,使用不同的實例而執(zhí)行不同操作
    2022-05-05
  • 從0到1構(gòu)建springboot web應(yīng)用鏡像并使用容器部署的過程

    從0到1構(gòu)建springboot web應(yīng)用鏡像并使用容器部署的過程

    這篇文章主要介紹了從0到1構(gòu)建springboot web應(yīng)用鏡像并使用容器部署,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-03-03
  • Java實現(xiàn)合并兩個word文檔內(nèi)容

    Java實現(xiàn)合并兩個word文檔內(nèi)容

    這篇文章主要為大家詳細介紹了如何使用Java實現(xiàn)合并兩個word文檔內(nèi)容,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-11-11
  • java線程池實現(xiàn)批量下載文件

    java線程池實現(xiàn)批量下載文件

    這篇文章主要為大家詳細介紹了java線程池實現(xiàn)批量下載文件,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-07-07

最新評論