Spring Boot2配置Swagger2生成API介面文檔

来源:https://www.cnblogs.com/jadite/archive/2022/09/13/16689993.html
-Advertisement-
Play Games

本文詳細闡述了knn演算法,從開始介紹什麼事knn,到講解knn演算法的原理再到最後以實際例子來運用knn演算法的步驟,實際例子的代碼講解也十分詳細 ...


一、Swagger2介紹

前後端分離開發模式中,api文檔是最好的溝通方式。
Swagger 是一個規範和完整的框架,用於生成、描述、調用和可視化 RESTful 風格的 Web 服務。

  • 及時性 (介面變更後,能夠及時準確地通知相關前後端開發人員)
  • 規範性 (並且保證介面的規範性,如介面的地址,請求方式,參數及響應格式和錯誤信息)
  • 一致性 (介面信息一致,不會出現因開發人員拿到的文檔版本不一致,而出現分歧)
  • 可測性 (直接在介面文檔上進行測試,以方便理解業務)

二、配置Swagger2

1、引入相關依賴

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

2、創建swagger的配置類

@Configuration
@EnableSwagger2
public class SwaggerConfig {

    @Bean
    public Docket webApiConfig(){
        return new Docket(DocumentationType.SWAGGER_2)
                .groupName("webApi")
                .apiInfo(webApiInfo())
                .select()
                .paths(Predicates.not(PathSelectors.regex("/admin/.*")))
                .paths(Predicates.not(PathSelectors.regex("/error.*")))
                .build();

    }

    private ApiInfo webApiInfo(){

        return new ApiInfoBuilder()
                .title("XX平臺API文檔")
                .description("本文檔描述了xxx介面定義")
                .version("1.0")
                // 創建人
                .contact(new Contact("Jade", "http://jade.com", "[email protected]"))
                .build();
    }
}

3、在啟動類上添加註解掃描swagger的配置類,進行測試

要能掃描到swagger的配置類SwaggerConfig

@SpringBootApplication
// 要能掃描到swagger的配置類SwaggerConfig
@ComponentScan(basePackages = {"com.jade"})
public class Application {
    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}

4、API模型

可以添加一些自定義設置,例如:
定義樣例數據

@ApiModelProperty(value = "創建時間", example = "2019-01-01 8:00:00")
@TableField(fill = FieldFill.INSERT)
private Date gmtCreate;

@ApiModelProperty(value = "更新時間", example = "2019-01-01 8:00:00")
@TableField(fill = FieldFill.INSERT_UPDATE)
private Date gmtModified;

image

5、定義介面說明和參數說明

定義在類上:@Api
定義在方法上:@ApiOperation
定義在參數上:@ApiParam

@Api(description="講師管理")
@RestController
@RequestMapping("/admin/edu/teacher")
public class TeacherAdminController {

    @Autowired
    private TeacherService teacherService;

    @ApiOperation(value = "所有講師列表")
    @GetMapping
    public List<Teacher> list(){
        return teacherService.list(null);
    }

    @ApiOperation(value = "根據ID刪除講師")
    @DeleteMapping("{id}")
    public boolean removeById(
            @ApiParam(name = "id", value = "講師ID", required = true)
            @PathVariable String id){
        return teacherService.removeById(id);
    }
}

6、測試,查看效果

訪問http://localhost:8080/swagger-ui.html 即可

image


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Hello,我是你們的好朋友小烤鴨,這過了個中秋節,胡吃海喝了兩日,學習拉下了,今天返崗,繼續把我們的設計模式撿起,希望我能堅持完這個系列吧,下麵我們就進入正題吧。 在軟體開發過程中,我們需要重覆使用某個對象的時候,如果重覆地new這個對象,不停地申請記憶體空間,會造成記憶體空間的極大浪費,在之後程式運 ...
  • 本文主要給出了電商平臺通用取貨碼的完整設計思路,按此思路可以實現大多數核銷類券碼的生成問題,也能夠滿足SaaS化的業務 ...
  • 我的博客在看到這個標題時候肯定有人會想,我寫SQL直接在資料庫工具上執行就行了啊,工具會自動識別註釋的,就是不用工具,把SQL寫到存儲過程里,資料庫也會識別註釋不執行的,幹嘛非要去掉,費力不討好。 其實是最近在做一個項目,需要在行雲庫里執行SQL,並且SQL是寫在腳本上的,通過JDBC調用,眾所周知 ...
  • 前言 CMake是C++的必學部分,本篇文章從安裝環境開始,通過使用CMake構建一個最簡單的cpp項目和g++直接編譯作對比瞭解CMake的構建過程,為接下來深入學習CMake打下基礎。 一、系統環境 操作系統:Windows7 sp1 專業版 構建工具:CMake 3.24.1 下載地址:htt ...
  • 函數的地址是存儲其機器語言代碼的記憶體的開始地址。可以編寫將另一個函數的地址作為參數的函數,它允許在不同的時間傳遞不同函數的地址,這意味著可以在不同的時間使用不同的函數。 ...
  • 可用七種不同的方式將 const 關鍵字用於二級指針,如下所示: //方式一:所指一級指針指向的數據為常量,以下幾種為等效表示 const int ** pptc; //方式一 int const ** pptc; //方式二 //方式二:所指一級指針為常量 int *const* pcpt; // ...
  • 可用三種不同的方式將 const 關鍵字用於一級指針,如下所示: //方式一:指向常量數據的指針,以下幾種為等效表示 const int * ptc; //方式一 int const * ptc; //方式二 //方式二:指針本身為常量,需在聲明時初始化 int x = 55; int * cons ...
  • 前言 嗨嘍,大家好呀~這裡是愛看美女的茜茜吶 又到了學Python時刻~ 今天實現一下人臉識別。 先問大家一個問題什麼是百度Aip模塊? 百度AI平臺提供了很多的API介面供開發者快速的調用運用在項目中本文寫的是使用百度AI的線上介面SDK模塊(baidu-aip)進行實現人臉識別 除了人臉識別,其 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 在我們開發過程中基本上不可或缺的用到一些敏感機密數據,比如SQL伺服器的連接串或者是OAuth2的Secret等,這些敏感數據在代碼中是不太安全的,我們不應該在源代碼中存儲密碼和其他的敏感數據,一種推薦的方式是通過Asp.Net Core的機密管理器。 機密管理器 在 ASP.NET Core ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 順序棧的介面程式 目錄順序棧的介面程式頭文件創建順序棧入棧出棧利用棧將10進位轉16進位數驗證 頭文件 #include <stdio.h> #include <stdbool.h> #include <stdlib.h> 創建順序棧 // 指的是順序棧中的元素的數據類型,用戶可以根據需要進行修改 ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • C總結與剖析:關鍵字篇 -- <<C語言深度解剖>> 目錄C總結與剖析:關鍵字篇 -- <<C語言深度解剖>>程式的本質:二進位文件變數1.變數:記憶體上的某個位置開闢的空間2.變數的初始化3.為什麼要有變數4.局部變數與全局變數5.變數的大小由類型決定6.任何一個變數,記憶體賦值都是從低地址開始往高地 ...
  • 如果讓你來做一個有狀態流式應用的故障恢復,你會如何來做呢? 單機和多機會遇到什麼不同的問題? Flink Checkpoint 是做什麼用的?原理是什麼? ...
  • C++ 多級繼承 多級繼承是一種面向對象編程(OOP)特性,允許一個類從多個基類繼承屬性和方法。它使代碼更易於組織和維護,並促進代碼重用。 多級繼承的語法 在 C++ 中,使用 : 符號來指定繼承關係。多級繼承的語法如下: class DerivedClass : public BaseClass1 ...
  • 前言 什麼是SpringCloud? Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的開發便利性簡化了分散式系統的開發,比如服務註冊、服務發現、網關、路由、鏈路追蹤等。Spring Cloud 並不是重覆造輪子,而是將市面上開發得比較好的模塊集成進去,進行封裝,從 ...
  • class_template 類模板和函數模板的定義和使用類似,我們已經進行了介紹。有時,有兩個或多個類,其功能是相同的,僅僅是數據類型不同。類模板用於實現類所需數據的類型參數化 template<class NameType, class AgeType> class Person { publi ...
  • 目錄system v IPC簡介共用記憶體需要用到的函數介面shmget函數--獲取對象IDshmat函數--獲得映射空間shmctl函數--釋放資源共用記憶體實現思路註意 system v IPC簡介 消息隊列、共用記憶體和信號量統稱為system v IPC(進程間通信機制),V是羅馬數字5,是UNI ...