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

Spring?Boot?集成?Swagger2構(gòu)建?API文檔

 更新時間:2022年05月23日 09:56:07   作者:村雨遙  
這篇文章主要介紹了Spring?Boot?集成?Swagger2構(gòu)建?API文檔,通過使用?Swagger,我們只需要按照它所給定的一系列規(guī)范去定義接口以及接口的相關(guān)信息,然后它就能幫我們自動生成各種格式的接口文檔,方便前后端開發(fā)者進行前后端聯(lián)調(diào),下文需要的朋友可以參考一下

前言:

不管你是從事前端還是后端開發(fā),相信都難免被接口文檔折磨過。如果你是一個前端開發(fā)者,可能你會經(jīng)常發(fā)現(xiàn)后端給的接口文檔跟實際代碼有所出入。而假設(shè)你是一個后端開發(fā)者,你可能又會覺得自己開發(fā)后端接口已經(jīng)夠煩的了,還要花費大量精力去編寫和維護接口文檔,所以難免有時候會更新不及時。這就可能造成了前后端相互不理解,最后甚至吵起來,哈哈哈 。

這時候我們就會想,有沒有一款工具,能讓我們快速實現(xiàn)編寫接口文檔。這個工具既能保證我們的接口文檔實時更新,也能保證我們不用花過多時間去維護,就像寫注釋那么簡單。

既然這是大多數(shù)前后端程序員的一大痛點,那必須得有一個解決方案吧。而這個方案使用的人多了,慢慢就成了一種規(guī)范,大家都默認使用這個方案,從而解決前后端接口文檔不同步的問題,而這就是我們今天的主角 - Swagger 的由來。

通過使用 Swagger,我們只需要按照它所給定的一系列規(guī)范去定義接口以及接口的相關(guān)信息,然后它就能幫我們自動生成各種格式的接口文檔,方便前后端開發(fā)者進行前后端聯(lián)調(diào)。同時,如果我們的代碼接口有所變動,只需要更新 Swagger 的描述,它就能進行實時更新,做到實際代碼和接口文檔的一致性。

一、Swagger 是什么

Swagger 是一種接口描述語言,主要用于生成、描述、調(diào)用以及可視化 RESTful 風格的 Web 服務(wù)接口文檔。以前的項目可能更多的是前后端未分開同時進行開發(fā),所以接口文檔可能不是那么重要。但現(xiàn)在主流的項目基本都是前后端分離,如果前后端沒有溝通好,就有可能導致接口文檔更新不及時,造成一些不必要的麻煩。而通俗地講,Swagger 就是幫我們寫接口文檔的。它不僅能自動生成實時接口文檔,還能生成測試用例,方便我們進行測試。

Swagger 主要提供了如下幾種開源工具:

1.Swagger Editor

Swagger 所提供的的編輯器,主要用于編輯 Swagger 描述文件,支持實時預(yù)覽描述文件更新后的效果,類似于我們的 Markdown 編輯器,左邊編寫源碼,右邊就可以進行實時預(yù)覽。該編輯器不僅提供在線使用,還支持本地部署。

2.Swagger UI

提供可視化的 UI 頁面,用于展示 Swagger 的描述文件。接口的調(diào)用方、測試等都可以通過該頁面查閱接口的相關(guān)信息,并且進行簡單的接口請求測試。

3.Swagger Codegen

通過使用該工具,可以將 Swagger 的描述文件生成 HTML 和 CWIKI 形式的接口文檔,而且還能生成針對多種不同語言的服務(wù)端和客戶端的代碼。

4.Swagger UI

平時和我們打交道最多的,可能就是 Swagger UI 這個工具了,它主要用于顯示接口文檔。根據(jù)我們代碼中按照 Swagger 規(guī)范所設(shè)置的描述,自動生成接口說明文檔。一個簡單的示例如下:

二、Spring Boot 集成 Swagger

1.創(chuàng)建 Spring Boot 項目

通過以上對 Swagger 簡單的介紹之后,我們來看看如何在 Spring Boot 項目中使用 Swagger。

首先需要創(chuàng)建一個簡單的 Spring Boot 項目,如果你還不知道如何創(chuàng)建,可以參考Spring Boot 教程之創(chuàng)建項目的三種方式

創(chuàng)建好之后的項目接口如下:

2.引入依賴

創(chuàng)建好Spring Boot 項目之后,需要配置項目 pom.xml 文件,在其中引入 Swagger 的相關(guān)依賴。

<dependency>
? ? <groupId>io.springfox</groupId>
? ? <artifactId>springfox-swagger2</artifactId>
? ? <version>2.9.2</version>
</dependency>

<dependency>
? ? <groupId>io.springfox</groupId>
? ? <artifactId>springfox-swagger-ui</artifactId>
? ? <version>2.9.2</version>
</dependency>

3.構(gòu)建 Swagger 配置類

引入依賴后,接下來就是構(gòu)建 Swagger 的配置類了。

package com.cunyu.springbootswaggerdemo.config;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;

import java.util.ArrayList;

@Configuration
@EnableSwagger2
public class Swagger2Configuration {

? ? /**
? ? ?* 配置 Swagger 2
? ? ?* 注冊一個 Bean 屬性
? ? ?* enable():是否啟用 Swagger,啟用后才能在瀏覽器中進行訪問
? ? ?* groupName():用于配置 API 文檔的分組
? ? ?*/
? ? @Bean
? ? public Docket docket() {
? ? ? ? return new Docket(DocumentationType.SWAGGER_2)
? ? ? ? ? ? ? ? .apiInfo(apiInfo())
? ? ? ? ? ? ? ? .enable(true)
? ? ? ? ? ? ? ? .groupName("v1")
? ? ? ? ? ? ? ? .select()
? ? ? ? ? ? ? ? // 過濾路徑
? ? ? ? ? ? ? ? //.paths(PathSelectors.ant())
? ? ? ? ? ? ? ? // 指定掃描的包
? ? ? ? ? ? ? ? .apis(RequestHandlerSelectors.basePackage("com.cunyu.springbootswaggerdemo.controller"))
? ? ? ? ? ? ? ? .build();
? ? }

? ? private ApiInfo apiInfo() {
? ? ? ? /*作者信息*/
? ? ? ? Contact contact = new Contact("村雨遙", "https://cunyu1943.github.io", "747731461@qq.com");
? ? ? ? return new ApiInfo(
? ? ? ? ? ? ? ? "Swagger 測試接口文檔",
? ? ? ? ? ? ? ? "Spring Boot 集成 Swagger 測試接口文檔",
? ? ? ? ? ? ? ? "v1.0",
? ? ? ? ? ? ? ? "https://cunyu1943.github.io",
? ? ? ? ? ? ? ? contact,
? ? ? ? ? ? ? ? "Apache 2.0",
? ? ? ? ? ? ? ? "http://www.apache.org/licenses/LICENSE-2.0",
? ? ? ? ? ? ? ? new ArrayList()
? ? ? ? );
? ? }
}

4.編寫接口

配置好 Swagger 后,在我們的項目中添加一個簡單的接口,這里以一個簡單的有參和無參接口為例。

package com.cunyu.springbootswaggerdemo.controller;

import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import io.swagger.annotations.ApiParam;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RestController;


@Api
@RestController
public class SwaggerDemoController {
? ? @ApiOperation(value = "hello world 接口")
? ? @GetMapping("hello")
? ? public String hello() {
? ? ? ? return "hello world";
? ? }

? ? @ApiOperation(value = "有參接口")
? ? @PostMapping("demo")
? ? public String demo(@ApiParam(name = "name", value = "村雨遙", required = true) String name) {
? ? ? ? return "hello," + name;
? ? }
}

5.查看并測試接口

完成上述步驟后,我們啟動項目,然后在瀏覽器中訪問如下地址,就可以訪問我們項目的接口文檔了。

http://localhost:8080/swagger-ui.html

訪問如上地址后,如果出現(xiàn)下面的界面,說明我們 Spring Boot 集成 Swagger2 就到此成功了。

點開具體的接口,就會有這個接口的一些詳細信息,如下圖所示,一般包括:

  • 接口請求方式
  • 接口請求路徑及描述
  • 接口請求參數(shù)
  • 接口響應(yīng)

如果我們要進行簡單的測試,則點擊上圖中右上方的 Try it out,然后我們就可以編輯請求參數(shù)的值,編輯完成之后點擊下方的 Execute 即可查看接口返回值。

以我給的接口為例,我傳入了一個參數(shù) name,然后執(zhí)行 demo 接口,最后會給我返回 hello,name 的結(jié)果,其中 name 是我傳入的參數(shù)值,這里我傳入了村雨遙,所以結(jié)果應(yīng)該會得到 hello,村雨遙,可以看到 Swagger 測試中也給我返回了對應(yīng)的結(jié)果,說明我們的接口測試成功!

注意:
如果在整合過程中出現(xiàn)如下錯誤:

org.springframework.context.ApplicationContextException:Failed to start bean 'documentationPluginsBootstrapper'; nested exception is java.lang.NullPointerException

這里可能是由于 Spring Boot 版本過高導致,我寫作本文時,一開始使用的 SpringBoot 2.6.2 版本,所以出現(xiàn)了該錯誤,而當我將 SpringBoot 降級為 2.5.6 時,該錯誤就不再出現(xiàn)。所以如果你也出現(xiàn)了這個問題,也可以嘗試降低 SpringBoot 版本來解決。

總結(jié):

以上就是本文的所有內(nèi)容了,主要對 Swagger 進行了簡單介紹,并用 Spring Boot 集成 Swagger,同時還進行簡單的測試。

到此這篇關(guān)于Spring Boot 集成 Swagger2構(gòu)建 API文檔的文章就介紹到這了,更多相關(guān)構(gòu)建 API文檔內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解SpringBoot中使用JPA作為數(shù)據(jù)持久化框架

    詳解SpringBoot中使用JPA作為數(shù)據(jù)持久化框架

    這篇文章主要介紹了SpringBoot中使用JPA作為數(shù)據(jù)持久化框架的相關(guān)知識,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-03-03
  • 基于SpringBoot?Mock單元測試詳解

    基于SpringBoot?Mock單元測試詳解

    這篇文章主要介紹了基于SpringBoot?Mock單元測試詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • Java編程調(diào)用微信分享功能示例

    Java編程調(diào)用微信分享功能示例

    這篇文章主要介紹了Java編程調(diào)用微信分享功能,結(jié)合實例形式分析了java微信分享功能接口的定義與調(diào)用相關(guān)操作技巧,需要的朋友可以參考下
    2017-08-08
  • java中instanceof 關(guān)鍵字作用和實際用途詳解

    java中instanceof 關(guān)鍵字作用和實際用途詳解

    這篇文章主要介紹了java中instanceof 關(guān)鍵字作用和實際用途,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-04-04
  • java通過方向鍵控制小球移動的小游戲

    java通過方向鍵控制小球移動的小游戲

    這篇文章主要為大家詳細介紹了java通過方向鍵控制小球移動的小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • Java?SE之了解泛型

    Java?SE之了解泛型

    這篇文章主要介紹了Java?SE之了解泛型,文章內(nèi)容詳細,簡單易懂,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2023-01-01
  • Java8新特性時間日期庫DateTime API及示例詳解

    Java8新特性時間日期庫DateTime API及示例詳解

    這篇文章主要介紹了Java8新特性時間日期庫DateTime API及示例詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-10-10
  • Springmvc加ajax實現(xiàn)上傳文件并頁面局部刷新

    Springmvc加ajax實現(xiàn)上傳文件并頁面局部刷新

    這篇文章主要介紹了Springmvc加ajax實現(xiàn)上傳文件并頁面局部刷新,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-06-06
  • java獲取當前時間和前一天日期(實現(xiàn)代碼)

    java獲取當前時間和前一天日期(實現(xiàn)代碼)

    java獲取當前時間和前一天日期的實現(xiàn)代碼。需要的朋友可以過來參考下,希望對大家有所幫助
    2013-10-10
  • MybatisPlus #{param}和${param}的用法詳解

    MybatisPlus #{param}和${param}的用法詳解

    這篇文章主要介紹了MybatisPlus #{param}和${param}的用法詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09

最新評論